網站首頁 編程語言 正文
你好,一般情況下,Ctrl+C 是最簡單的方法,當無法 Ctrl+C 時,我們借助于 Python,以下是具體步驟:
第一步,安裝工具庫
1、tika — 用于從各種文件格式中進行文檔類型檢測和內容提取
2、wand — 基于 ctypes 的簡單 ImageMagick 綁定
3、pytesseract — OCR 識別工具
創建一個虛擬環境,安裝這些工具
python -m venv venv
source venv/bin/activate
pip install tika wand pytesseract
第二步,編寫代碼
假如 pdf 文件里面既有文字,又有圖片,以下代碼可以直接識別文字:
import io
import pytesseract
import sys
from PIL import Image
from tika import parser
from 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 io
import sys
from PIL import Image
import pytesseract
from wand.image import Image as wi
from 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 是這樣的:
在命令行這樣執行:
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
最后的話
從 PDF 中提取文本的腳本實現并不復雜,許多庫簡化了工作并取得了很好的效果
原文鏈接:https://blog.csdn.net/somenzz/article/details/124440977
相關推薦
- 2022-10-28 keepalived對nginx進行高可用搭建及原理詳解_nginx
- 2022-04-09 一起來了解python的運算符_python
- 2022-08-25 C++示例講解string容器_C 語言
- 2023-03-21 Golang使用Gin創建Restful?API的實現_Golang
- 2022-11-30 ASP.NET?MVC實現本地化和全球化_實用技巧
- 2023-12-22 onReachBottom觸底觸發事件
- 2022-06-25 iOS自定義滑桿效果_IOS
- 2022-07-06 YOLOv5目標檢測之anchor設定_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支