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

    目錄

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

    第一步,安裝工具庫

    1、tika — 用于從各種文件格式中進(jìn)行文檔類型檢測和內(nèi)容提取

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

    3、pytesseract — OCR 識別工具

    創(chuàng)建一個虛擬環(huán)境,安裝這些工具

    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])

    第三步,執(zhí)行

    假如 example.pdf 是這樣得:

    1f7cd9c778e1c3cfe5b9a0d36ea69272.png

    在命令行這樣執(zhí)行:

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

    最終 extract.txt 得結(jié)果如下:

    -- 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 參數(shù)傳遞什么,傳 'chi_sim',其實是有官方說明得,鏈接如下:

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

    0361bb52f8ded0538c545369c2c0254f.png

    最后得話

    從 PDF 中提取文本得實現(xiàn)并不復(fù)雜,許多庫簡化了工作并取得了很好得效果

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

    聲明:所有內(nèi)容來自互聯(lián)網(wǎng)搜索結(jié)果,不保證100%準(zhǔn)確性,僅供參考。如若本站內(nèi)容侵犯了原著者的合法權(quán)益,可聯(lián)系我們進(jìn)行處理。
    發(fā)表評論
    更多 網(wǎng)友評論1 條評論)
    暫無評論

    返回頂部

    主站蜘蛛池模板: 亚洲欧洲一区二区三区| 国99精品无码一区二区三区| 亚洲日韩精品无码一区二区三区| 亚洲AV无码一区二区三区在线 | 日本免费一区二区三区| 精品女同一区二区三区在线| 亚洲视频一区网站| 亚洲国产精品一区二区第一页| 无码精品不卡一区二区三区| 精品无码日韩一区二区三区不卡 | 一区二区三区视频在线播放| 亚洲av无码片vr一区二区三区| 亚洲AV无码一区二区二三区软件 | 亚洲中文字幕丝袜制服一区 | 无码精品黑人一区二区三区| 久久国产精品免费一区| 国产成人精品a视频一区| 日韩av片无码一区二区三区不卡 | 夜色阁亚洲一区二区三区| 精品久久久久久中文字幕一区| 中文字幕av一区| 亚洲欧美日韩一区二区三区| 中文乱码字幕高清一区二区| 国产精品无码亚洲一区二区三区 | 亚洲AV日韩AV天堂一区二区三区 | 久久久久人妻精品一区三寸| 亚洲一区二区三区写真| 在线精品视频一区二区| 无码国产精品一区二区免费I6| 色综合视频一区中文字幕| 精品国产一区二区三区久久影院| 国产一区在线观看免费| av在线亚洲欧洲日产一区二区| 国产精品小黄鸭一区二区三区| 在线观看免费视频一区| 搡老熟女老女人一区二区| 交换国产精品视频一区| 国产免费av一区二区三区| 国产精品免费大片一区二区| 国产成人精品无码一区二区| 中字幕一区二区三区乱码|