Python + Tesseract-OCR识别图片文字

考试答题偶然一次需要提取图片中的文字,所以搜索了一下解决方法

测试代码如下:

from PIL import Image
import pytesseract

text=pytesseract.image_to_string(Image.open('../Demo/Chinese.png'),lang='chi_sim')
print(text)

1.第一步首先的话需安装pytesseract和Pillow库

2.然后的话安装识别引擎tesseract-ocr
地址:https://github.com/UB-Mannheim/tesseract/wiki
根据自己的需求选择其中w32表示32位系统,w64表示64位系统下载,对应的版本即可
在这里插入图片描述
3.下载后安装tesseract-ocr,安装后还需进行环境变量
根据自己实际的安装路径即可
在这里插入图片描述
TESSDATA_PREFIX
D:\应用\Tesseract-OCR\tessdata
在这里插入图片描述
4.然后还需修改pytesseract.py文件,在python下的Lib\site-packages\pytesseract,找到pytesseract.py并修改其中的tesseract_cmd

tesseract_cmd = r'D:\应用\Tesseract-OCR\tesseract.exe'

之后就可以运行了。

5.如果需识别中文的情况下,还需单独安装上识别引擎是无法识别中文的,需要另外下载一些东西
地址:https://github.com/tesseract-ocr/tessdata
将里面的 chi_sim.traineddata、chi_sim_vert.traineddata、chi_tra.traineddata和chi_tra_vert.traineddata文件放入tesseract-ocr的tessdata目录下
在这里插入图片描述
找了个图片实验了一下
在这里插入图片描述
总的来说不是很准确,Tesseract对手写体、行楷等飘逸的字体识别不准确,对一些复杂的字识别也有待提升。但是宋体、印刷体等笔画严谨的字体识别准确率很高。另外如果图片的倾斜大于一定的角度,识别结果也会有很大差别。

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值