您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:如何使用Python进行PDF图片识别OCR

51自学网 2021-10-30 23:07:19
  python
这篇教程如何使用Python进行PDF图片识别OCR写得很实用,希望能帮到您。

使用场景

使用图片识别可以快速提取图片中的信息,方便高效。

Python并不能直接对PDF进行识别,所以如果是识别PDF的话,需要先将PDF转化为图片,然后再进行识别。

必备工具

  • Python 

可以安装3.7及以上版本

  • tesseract-ocr 

下载地址: https://github.com/UB-Mannheim/tesseract/wiki 使用最新版本即可

  • 需要用到的库
pip install pillowpip install opencv-pythonpip install fitzpip install PyMuPDFpip install pytesseract

代码示例

from PIL import Imageimport osimport pytesseract import cv2 as cvimport fitzdef pdf_image(pdfPath,imgPath,zoom_x,zoom_y,rotation_angle):  # 打开PDF文件  pdf = fitz.open(pdfPath)  # 逐页读取PDF  for pg in range(0, pdf.pageCount):    page = pdf[pg]    # 设置缩放和旋转系数    trans = fitz.Matrix(zoom_x, zoom_y).preRotate(rotation_angle)    pm = page.getPixmap(matrix=trans, alpha=False)    # 开始写图像    pm.writePNG(imgPath+str(pg)+".png")    #pm.writePNG(imgPath)  pdf.close()pdf_path ='D:/123.pdf'img_path ='D:/123.png'pdf_image(pdf_path,img_path,5,5,0)# 依赖opencvimg=cv.imread(img_path)text=pytesseract.image_to_string(Image.fromarray(img),lang='chi_tra')# 不依赖opencv写法# text=pytesseract.image_to_string(Image.open(img_path))print(text)

总结

识别清晰的文字图片的时候准确率非常高

但是识别手写体的话效果不太好

注意事项

在安装tesseract-ocr 的时候一定要记得选择对应的语言,不然是无法正常使用的。

以上就是如何使用Python进行PDF图片识别OCR的详细内容,更多关于python pdf图片识别ocr的资料请关注51zixue.net其它相关文章!


详解pandas映射与数据转换
python将YUV420P文件转PNG图片格式的两种方法
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。