Python2实现的图片文本识别功能详解


Posted in Python onJuly 11, 2018

本文实例讲述了Python2实现的图片文本识别功能。分享给大家供大家参考,具体如下:

这里需要用到python的几个库,分别是pytesser,以及pytesser的依赖库PIL。python的版本建议用2.7或者2.7一下的都行,不建议用python3以上的,因为python3不向下兼容,所以有很多python2的东西它不支持

pytesser下载的话,我直接在pycharm里面下全是失败,用DOS的命令行下也是失败,所以还是自己直接去google下吧
地址:http://code.google.com/p/pytesser/downloads/list

如果打不开上面的网址的话可以从我的资源里面下载,点击此处本站下载

下载好了之后安装,步骤:

1.  解压pytesser ,将解压后的文件复制到Python安装目录的Lib\site-packages下,直接使用,比如我的安装目录是:C:\Python27\Lib\site-packages

2. 这里我建立好的pytesser目录为C:\Python27\Lib\site-packages\pytesser\

3. 接下来打开pytesser文件夹,将pytesser.py修改成__init__.py,然后打开py文件进行修改:
①. import Image 改为: from PIL import Image
②. tesseract_exe_name = 'tesseract' —> tesseract_exe_name = 'C:\\Python27\\Lib\\site-packges\\pytesser\\tesseract,注意双斜杠,否则可能因为转义字符报错

接下来就是下载PIL了。这个我在pycharm里面也是下载失败,提示没有找到适合python版本的PIL。
可以在DOS命令行下用命令下:pip install Pillow 这里要注意的是如果要直接在DOS下用pip命令的话要先把pip的路径加到环境变量path里面去,例如我的pip路径:“D:\python2.7.13\Scripts\

注:小编尝试后发现PIL安装很麻烦,推荐下载exe直接安装

具体可至PIL官网查找对应安装版本:http://pythonware.com/products/pil/

全部下载完之后就可以开始拿图片测试了。这里我们先拿上面下载的pytesser压缩包里面给的测试图片来测试
代码如下:

from pytesser import *
img=Image.open("D:\\fnord.tif") 
#我这里是直接把图片复制在d盘下。可以随意更改。如果是d盘下的XX文件夹,路径就是:d:\XX\\fnord.tif
#一些对python不熟悉的小伙伴要注意的是这个路径只有最后一个斜杠要改成双斜杠,前面的都是单斜杠,如果不是这样的话在pycharm里面就会报一些看不懂的错误,百度到死都不知道怎么解决。
print image_to_string(img)

或者可以写成:

print image_file_to_string("D:\\fnord.tif")

这里需要注意一下,直接运行上面的代码的话可能会报一个找不到Image类的错误,具体我也不是很清楚,可能是因为pytesser只支持PIL的Image类吧,因此我们还要改一个东西,就是上面步骤3中pytesser包里面__init__.py 文件的第一行:import Image改成from PIL import Image。如图:

 Python2实现的图片文本识别功能详解

这时候就可以看到输出结果:

 Python2实现的图片文本识别功能详解

大功告成。

最后说一下这个方法的一些缺点,就是识别率不高,要图片里面的文字很清晰才可以识别出来,要想提高识别率的话还要对图片进行一些操作,这里就不详细说啦,请大家自行百度。

更多关于Python相关内容可查看本站专题:《Python数学运算技巧总结》、《Python图片操作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
浅析Python中MySQLdb的事务处理功能
Sep 21 Python
Python制作Windows系统服务
Mar 25 Python
Python用户推荐系统曼哈顿算法实现完整代码
Dec 01 Python
python 剪切移动文件的实现代码
Aug 02 Python
python抓取搜狗微信公众号文章
Apr 01 Python
python+opencv实现摄像头调用的方法
Jun 22 Python
对Pytorch中nn.ModuleList 和 nn.Sequential详解
Aug 18 Python
Python箱型图处理离群点的例子
Dec 09 Python
python继承threading.Thread实现有返回值的子类实例
May 02 Python
Python实现智慧校园自动评教全新版
Jun 18 Python
Pandas 稀疏数据结构的实现
Jul 25 Python
关于 Python json中load和loads区别
Nov 07 Python
利用Python进行数据可视化常见的9种方法!超实用!
Jul 11 #Python
基于数据归一化以及Python实现方式
Jul 11 #Python
numpy.std() 计算矩阵标准差的方法
Jul 11 #Python
使用sklearn进行对数据标准化、归一化以及将数据还原的方法
Jul 11 #Python
使用sklearn之LabelEncoder将Label标准化的方法
Jul 11 #Python
Python实现识别图片内容的方法分析
Jul 11 #Python
对python 数据处理中的LabelEncoder 和 OneHotEncoder详解
Jul 11 #Python
You might like
PHP中的float类型使用说明
2010/07/27 PHP
PHP程序员必须清楚的问题汇总
2014/12/18 PHP
PHP自动生成缩略图函数的源码示例
2019/03/18 PHP
List the UTC Time on a Computer
2007/06/11 Javascript
JS 显示当前日期与时间的代码
2010/03/24 Javascript
javascript模版引擎-tmpl的bug修复与性能优化分析
2011/10/23 Javascript
JS文本框不能输入空格验证方法
2013/03/19 Javascript
Js 正则表达式知识汇总
2014/12/02 Javascript
jQuery中siblings()方法用法实例
2015/01/08 Javascript
JQuery实现防止退格键返回的方法
2015/02/12 Javascript
前端框架Vue.js中Directive知识详解
2016/09/12 Javascript
JavaScript中在光标处插入添加文本标签节点的详细方法
2017/03/22 Javascript
iview日期控件,双向绑定日期格式的方法
2018/03/15 Javascript
Vue项目自动转换 px 为 rem的实现方法
2018/10/29 Javascript
javascript实现自由编辑图片代码详解
2019/06/21 Javascript
vue移动端下拉刷新和上滑加载
2020/10/27 Javascript
vue实现登录、注册、退出、跳转等功能
2020/12/23 Vue.js
在Python上基于Markov链生成伪随机文本的教程
2015/04/17 Python
python3中函数参数的四种简单用法
2018/07/09 Python
Python 调用 zabbix api的方法示例
2019/01/06 Python
Python Selenium 之关闭窗口close与quit的方法
2019/02/13 Python
Python XlsxWriter模块Chart类用法实例分析
2019/03/11 Python
python3.7简单的爬虫实例详解
2019/07/08 Python
python实现飞行棋游戏
2020/02/05 Python
Python3-异步进程回调函数(callback())介绍
2020/05/02 Python
Python gevent协程切换实现详解
2020/09/14 Python
英国巧克力贸易公司:Chocolate Trading Company
2017/03/21 全球购物
商务英语毕业生自荐信范文
2013/11/08 职场文书
出生医学证明样本
2014/01/17 职场文书
小学一年级学生评语
2014/04/22 职场文书
五四演讲稿范文
2014/09/03 职场文书
2014年银行员工年终自我评价
2014/09/19 职场文书
2014年优质护理服务工作总结
2014/11/14 职场文书
公务员个人年终总结
2015/02/12 职场文书
煤矿安全学习心得体会
2016/01/18 职场文书
Lombok的详细使用及优缺点总结
2021/07/15 Java/Android