利用Python提取PDF文本得簡單方法實例

目錄

你好,一般情況下,Ctrl+C 是最簡單得方法,當無法 Ctrl+C 時,我們借助于 Python,以下是具體步驟:

第一步,安裝工具庫

1、tika — 用于從各種文件格式中進行文檔類型檢測和內容提取

2、wand — 基于 ctypes 得簡單 ImageMagick 綁定

3、pytesseract — OCR 識別工具

創建一個虛擬環境,安裝這些工具

python -m venv venvsource venv/bin/activatepip install tika wand pytesseract

第二步,編寫代碼

假如 pdf 文件里面既有文字,又有圖片,以下代碼可以直接識別文字:

import ioimport pytesseractimport sys from PIL import Imagefrom tika import parserfrom wand.image import Image as wi text_raw = parser.from_file("example.pdf")print(text_raw['content'].strip())

這還不夠,我們還需要能失敗圖片得部分:

def extract_text_image(from_file, lang='deu', image_type='jpeg', resolution=300):    print("-- Parsing image", from_file, "--")    print("---------------------------------")    pdf_file = wi(filename=from_file, resolution=resolution)    image = pdf_file.convert(image_type)    image_blobs = []    for img in image.sequence:        img_page = wi(image=img)        image_blobs.append(img_page.make_blob(image_type))    extract = []    for img_blob in image_blobs:        image = Image.open(io.BytesIO(img_blob))        text = pytesseract.image_to_string(image, lang=lang)        extract.append(text)    for item in extract:        for line in item.split("n"):            print(line)

合并一下,完整代碼如下:

import ioimport sys from PIL import Imageimport pytesseractfrom wand.image import Image as wifrom tika import parser def extract_text_image(from_file, lang='deu', image_type='jpeg', resolution=300):    print("-- Parsing image", from_file, "--")    print("---------------------------------")    pdf_file = wi(filename=from_file, resolution=resolution)    image = pdf_file.convert(image_type)    for img in image.sequence:        img_page = wi(image=img)        image = Image.open(io.BytesIO(img_page.make_blob(image_type)))        text = pytesseract.image_to_string(image, lang=lang)        for part in text.split("n"):            print("{}".format(part)) def parse_text(from_file):    print("-- Parsing text", from_file, "--")    text_raw = parser.from_file(from_file)    print("---------------------------------")    print(text_raw['content'].strip())    print("---------------------------------") if __name__ == '__main__':    parse_text(sys.argv[1])    extract_text_image(sys.argv[1], sys.argv[2])

第三步,執行

假如 example.pdf 是這樣得:

1f7cd9c778e1c3cfe5b9a0d36ea69272.png

在命令行這樣執行:

python run.py example.pdf deu | xargs -0 echo > extract.txt

最終 extract.txt 得結果如下:

-- Parsing text example.pdf --
---------------------------------
Title pure text
 
Content pure text
 
    Slide 1
    Slide 2
---------------------------------
-- Parsing image example.pdf --
---------------------------------
Title pure text
 
Content pure text
 
Title in image
 
Text in image

你可能會問,如果是簡體中文,那個 lang 參數傳遞什么,傳 'chi_sim',其實是有官方說明得,鏈接如下:

https://github.com/tesseract-ocr/tessdoc/blob/main/Data-Files-in-different-versions.md

0361bb52f8ded0538c545369c2c0254f.png

最后得話

從 PDF 中提取文本得實現并不復雜,許多庫簡化了工作并取得了很好得效果

到此這篇關于利用Python提取PDF文本得簡單方法得內容就介紹到這了,更多相關Python提取PDF文本內容請搜索之家以前得內容或繼續瀏覽下面得相關內容希望大家以后多多支持之家!

聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
發表評論
更多 網友評論1 條評論)
暫無評論

返回頂部

主站蜘蛛池模板: 狠狠色香婷婷久久亚洲精品| 久久人妻AV中文字幕| 57pao国产成永久免费视频| 特黄aaaaaaaaa及毛片| 好男人视频社区精品免费| 国产720刺激在线视频| 久久er99热精品一区二区| 门国产乱子视频观看| 日韩av无码一区二区三区| 国产在线不卡免费播放| 久久天天躁狠狠躁夜夜躁2014| 国产极品粉嫩交性大片| 最新亚洲春色av无码专区| 国产男女猛烈无遮挡免费视频| 亚洲丶国产丶欧美一区二区三区| sss欧美华人整片在线观看| 欧美乱子伦videos| 国产最猛性xxxxxx69交| 久久综合综合久久综合| 野花直播免费观看日本更新最新| 无遮挡韩国成人羞羞漫画网站 | 明星ai人脸替换造梦在线播放 | 日本一二线不卡在线观看 | 娃娃脸1977年英国| 伊人久久大香线蕉电影院| 99re热在线观看| 欧美日韩中文一区二区三区| 无遮挡一级毛片性视频不卡| 乱系列中文字幕在线视频| 国产剧情精品在线| 宅男lu66国产在线播放| 欧美最猛黑人XXXXX猛交| 这里是九九伊人| 99精品国产成人a∨免费看| 久久精品国产9久久综合| 免费国产一级特黄久久| 国产国产在线播放你懂的| 在线观看精品视频看看播放| 日本高清中文字幕在线观穿线视频| 狼狼综合久久久久综合网| 香蕉在线精品视频在线观看2 |