初探利用Python进行图文识别(OCR)


Posted in Python onFebruary 26, 2019

话说什么是OCR?????

简介

OCR技术是光学字符识别的缩写(Optical Character Recognition),是通过扫描等光学输入方式将各种票据、报刊、书籍、文稿及其它印刷品的文字转化为图像信息,再利用文字识别技术将图像信息转化为可以使用的计算机输入技术。可应用于银行票据、大量文字资料、档案卷宗、文案的录入和处理领域。适合于银行、税务等行业大量票据表格的自动扫描识别及长期存储。相对一般文本,通常以最终识别率、识别速度、版面理解正确率及版面还原满意度4个方面作为OCR技术的评测依据;而相对于表格及票据,通常以识别率或整张通过率及识别速度为测定OCR技术的实用标准。

解析

采用OCR识别技术,可以将其应用于银行票据光盘缩微系统,可以自动提取票据要素,可减轻操作员的工作量,减少重复劳动,尤其是在与银行事后且监督系统相结合后,可以替代原先的操作人员完成事后监督工作。由计算机自动识别票据上的日期、帐号、金额等要素,通过银行事后监督系统与业务系统中的数据进行比较,完成传统的事后监督操作;配有印章验证系统后,自动将凭证图像中的印章与系统中预留的印鉴进行比较,完成印章的真伪识别。

OCR识别技术不仅具有可以自动判断、拆分、识别和还原各种通用型印刷体表格,在表格理解上做出了令人满意的实用结果,能够自动分析文稿的版面布局,自动分栏、并判断出标题、横栏、图像、表格等相应属性,并判定识别顺序,能将识别结果还原成与扫描文稿的版面布局一致的新文本。表格自动录入技术,可自动识别特定表格的印刷或打印汉字、字母、数字,可识别手写体汉字、手写体字母、数字及多种手写符号,并按表格格式输出。提高了表格录入效率,可节省大量人力。同时支持将表格识别直接还原成PTF、PDF、HTML等格式文档;并可以对图像嵌入横排文本和竖排文本、表格文本进行自动排版面分析。

利用目前的高新技术-OCR,直接从凭证影像中提取金额、帐号等重要数据,代替人的手工录入,与条码识别/流水识别紧密结合,实现建立事后副本帐、完成事后监督的工作。OCR处理一般使用性能较好的PC机,OCR处理程序一经启动会自动扫描数据库中的凭证影像,发现有需OCR处理而未处理的,提取到本地进行处理。

 

OCR手写体、印刷体识别技术,能识别不同人写的千差万别的手写体汉字和数字,应用于本系统,识别凭证影像中储户填写的信息,如大写金额、小写金额、帐号、存期、日期、证件号等,可以代替手工录入。同时被识别得出的金额还要与流水识别所得的金额进行核对,核对成功,则OCR识别成功。这样处理是为了避免误判。

 

经过对银行产生的实际凭证进行的大量测试,在实际开发过程中,根据银行的实际需求,OCR技术在票据和表格识别能力和手写体自动识别能力上不断提升,目前处理速度可达到每分钟60~80张票据,存折识别率已经达到了85%以上,存单、凭条识别率达到90%以上,而85%以上的识别率就能减少80%以上的数据录入员。

在档案领域OCR技术使档案扫描成果达到了全文可识别,将档案数字化发展提升了到了一个新的阶段,是原本扫描出来的图片变得更容易进行检索,为数字档案馆的数据查询提供了技术支持,是档案数字化发展中必不可少的一环。

以上来自百度百科哈哈哈哈哈!!

相关的工具:Tesseract

Tesseract概述:

Tesseract 是一个OCR库,目前由Google赞助(Google也是一家以OCR和机器学习技术闻名于世的公司)。Tesseract是目前公认最优秀、最精确的开源OCR系统。

Tesseract的Windows安装包下载地址为:http://digi.bib.uni-mannheim.de/tesseract/tesseract-ocr-setup-4.00.00dev.exe,下载后双击直接安装即可。安装完后,需要将Tesseract添加到系统变量中。在CMD中输入tesseract-v,如显示以下界面,则表示Tesseract安装完成且添加到系统变量中。

初探利用Python进行图文识别(OCR)

配置完成后在命令行输入tesseract -v,如果出现如下图所示,说明环境变量配置成功

初探利用Python进行图文识别(OCR)

命令使用: tesseract C://Users\lenovo\Desktop\Tesseract-OCR\233.jpg C://Users\lenovo\Desktop\Tesseract-OCR\Max.txt,则会将233.jpg中的识别文字写入到Max.txt一执行报错???什么情况?

初探利用Python进行图文识别(OCR)

后来我找了一些资料来看 上面的意思就是说不能加载'eng'语言包。请将tessdata的父文件夹路径设置为TESSDATA_PREFIX环境变量值,这个就是说在环境变量中新建一个系统变量,变量名称为TESSDATA_PREFIX,tessdata是放置语言包的文件夹,一般在你安装tesseract的目录下,即tesseract的安装目录就是tessdata的父目录,把ESSDATA_PREFIX的值设置为它就没问题了

初探利用Python进行图文识别(OCR)

更改完成后重启就没问题了。

初探利用Python进行图文识别(OCR)

初探利用Python进行图文识别(OCR)

规整的中文也是可以识别的哦。

命令:tesseract C://Users\lenovo\Desktop\Tesseract-OCR\libai.png C://Users\lenovo\Desktop\Tesseract-OCR\libai.txt -l chi_sim

初探利用Python进行图文识别(OCR)

我们开始使用python编写识别小脚本了,这里我们需要一个pytesseract库使用pip install pytesseract安装。安装完后,就可以使用Python调用Tesseract这里我们还需要安装一个Python的图片处理模块,可以安装pillow.  

输入以下代码,可以实现同上述Tesseract命令一样的效果:

初探利用Python进行图文识别(OCR)

我们的图片里面内容是:

初探利用Python进行图文识别(OCR)

运行程序:

初探利用Python进行图文识别(OCR)

识别!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python改变日志(logging)存放位置的示例
Mar 27 Python
利用Python中的mock库对Python代码进行模拟测试
Apr 16 Python
Python数据结构之哈夫曼树定义与使用方法示例
Apr 22 Python
浅析python继承与多重继承
Sep 13 Python
Python面向对象程序设计中类的定义、实例化、封装及私有变量/方法详解
Feb 28 Python
Python XlsxWriter模块Chart类用法实例分析
Mar 11 Python
python标记语句块使用方法总结
Aug 05 Python
基于Python实现ComicReaper漫画自动爬取脚本过程解析
Nov 11 Python
在python中利用dict转json按输入顺序输出内容方式
Feb 27 Python
详解pyinstaller生成exe的闪退问题解决方案
Jun 19 Python
python 19个值得学习的编程技巧
Aug 15 Python
Python与C++中梯度方向直方图的实现
Mar 17 Python
Python编写合并字典并实现敏感目录的小脚本
Feb 26 #Python
Python实现监控Nginx配置文件的不同并发送邮件报警功能示例
Feb 26 #Python
利用python实现对web服务器的目录探测的方法
Feb 26 #Python
python selenium 弹出框处理的实现
Feb 26 #Python
python实现学员管理系统
Feb 26 #Python
python实现电子产品商店
Feb 26 #Python
Python selenium根据class定位页面元素的方法
Feb 26 #Python
You might like
Thinkphp的volist标签嵌套循环使用教程
2014/07/08 PHP
smarty缓存用法分析
2014/12/16 PHP
PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
2016/01/07 PHP
再谈PHP中单双引号的区别详解
2016/06/12 PHP
Yii视图CGridView实现操作按钮定义地址示例
2016/07/14 PHP
jquery中eq和get的区别与使用方法
2011/04/14 Javascript
js对象基础实例分析
2015/01/13 Javascript
全面解析Bootstrap表单使用方法(表单按钮)
2015/11/24 Javascript
详解JavaScript基于面向对象之创建对象(2)
2015/12/10 Javascript
JS实现微信弹出搜索框 多条件查询功能
2016/12/13 Javascript
mongoose更新对象的两种方法示例比较
2017/12/19 Javascript
在Vue组件上动态添加和删除属性方法
2018/02/23 Javascript
使用node.js实现微信小程序实时聊天功能
2018/08/13 Javascript
angularJs中$scope数据序列化的实例
2018/09/30 Javascript
如何在vue中使用HTML 5 拖放API
2021/01/14 Vue.js
[01:43]倾听DOTA2英雄之声 魅惑魔女国服配音鉴赏
2013/06/06 DOTA
[42:48]完美世界DOTA2联赛PWL S3 Magma vs INK ICE 第二场 12.11
2020/12/16 DOTA
详解使用 pyenv 管理多个版本 python 环境
2017/10/19 Python
Tensorflow 查看变量的值方法
2018/06/14 Python
解决python中遇到字典里key值为None的情况,取不出来的问题
2018/10/17 Python
PyTorch的Optimizer训练工具的实现
2019/08/18 Python
如何利用pycharm进行代码更新比较
2020/11/04 Python
利用python查看数组中的所有元素是否相同
2021/01/08 Python
CSS3区域模块region相关编写示例
2015/08/28 HTML / CSS
伦敦一家非常流行的时尚精品店:Oxygen Boutique
2017/01/15 全球购物
德国隐形眼镜店:LuckyLens
2018/07/29 全球购物
法律六进活动方案
2014/03/13 职场文书
员工入职担保书范文
2014/04/01 职场文书
陈胜吴广起义口号
2014/06/20 职场文书
优秀班主任主要事迹材料
2014/12/16 职场文书
一年级数学下册复习计划
2015/01/17 职场文书
检察院起诉书
2015/05/20 职场文书
新闻通讯稿模板
2015/07/22 职场文书
观看安全警示教育片心得体会
2016/01/15 职场文书
SQL注入详解及防范方法
2021/12/06 MySQL
Vue自定义铃声提示音组件的实现
2022/01/22 Vue.js