今天给大家分享批量识别图片的方法。

一、背景

也许你还记得,前不久复旦大学一博士生写了130行Python代码,批量识别核酸截图内容的故事。当时还被人民日报公众号报道出来,夸赞用所学贡献青春力量!

其实,批量文字识别(OCR)是Python办公自动化的基本操作,应用在我们工作生活中的方方面面,比如车牌识别、证件识别、银行卡识别、票据识别等等。

PythonOCR第三方库非常多,比如easyocrPaddleOCRcnocr等等。当然,直接调用百度API也是可以的,不过超过一定限额后要收费,因此本文主要以开源免费的easyocr来进行介绍。

二、需求

本文以证件识别为例,我网上找了3张虚拟身份证来实验:

运用easyocr进行识别并保存为Excel,效果如下:

三、实战

1.安装模块

Python中使用 easyocr非常简单,只要使用pip命令安装easyocr 即可(建议使用清华源,否则安装会比较慢)。

pip install easyocr

不过 easyocr 的深度学习算法依赖于另一个著名的第三方模块 pytorch,图形处理部分则会用到 opencvPillow 等,所以还需要确保自己电脑上已经安装这些基础模块。

2.识别一张图片

1.easyocr识别图片代码非常简洁,只需要创建一个easyocr.Reader类对象,指定以下两个常用参数:

  • 需要识别的文字属于哪几种语言

  • 是否启用GPU显卡加速

2.调用Reader对象的readtext方法,将图片中所有文字读入一个列表并返回。

'''
公众号:菜J学Python
作者:J哥
'''
# 导入模块
import easyocr
# 图片路径
image = './id_card/1.jpg'
# 创建ocr的reader对象,识别中英文
ocr = easyocr.Reader(['ch_sim', 'en'],gpu=False)
# 识别图片文字
content = ocr.readtext(image)
print(content)

识别结果如下:

[([[39, 31], [207, 31], [207, 67], [39, 67]], '姓  名  韦小宝', 0.8973890994570185), ([[40, 82], [159, 82], [159, 119], [40, 119]], '性  别  男', 0.9799311480828728), ([[178, 86], [272, 86], [272, 116], [178, 116]], '民 族汉', 0.5456928014755249), ([[40, 131], [100, 131], [100, 161], [40, 161]], '出  生', 0.5362269878387451), ([[114, 134], [240, 134], [240, 162], [114, 162]], '1654 年12', 0.6952526392609933), ([[266, 134], [322, 134], [322, 162], [266, 162]], '20日', 0.31329770168285426), ([[42, 181], [395, 181], [395, 213], [42, 213]], '住  址  北京市东城区景山前街4号', 0.48138251996753667), ([[112, 222], [256, 222], [256, 254], [112, 254]], '紫禁城敬事房', 0.9732440311960702), ([[44, 307], [195, 307], [195, 337], [44, 337]], '公民身份证号码', 0.612808391503521), ([[212, 308], [526, 308], [526, 334], [212, 334]], '112044165412202438', 0.7003081027071493)]

readtext 返回的列表中,每个元素都是一个元组,内含三个信息:位置、文字、置信度。我们可以在调用readtext时指定一个参数 detail=0,从而只返回文字内容。于是修改后代码和效果如下:

import easyocr
image = './id_card/1.jpg'
ocr = easyocr.Reader(['ch_sim', 'en'],gpu=False)
content = ocr.readtext(image,detail=0)
print(content)
['姓  名  韦小宝', '性  别  男', '民 族汉', '出  生', '1654 年12', '20日', '住  址  北京市东城区景山前街4号', '紫禁城敬事房', '公民身份证号码', '112044165412202438']

3.批量识别图片

批量识别图片无非就是遍历图片文件夹,这里用到了os.listdir()方法以返回文件列表。然后用ocr.readtext()去识别每一张图片文字内容,接着通过字符串切片来获取姓名、性别、民族、出生、住址和身份证号等关键信息,最后统一将这些信息存入列表data中。

'''
公众号:菜J学Python
作者:J哥
'''import easyocr
import os# 指明所有图片所在的文件夹
images = './id_card'
# 创建ocr的reader对象,识别中英文
ocr = easyocr.Reader(['ch_sim', 'en'])
# 识别图片文字
content = ocr.readtext(images,detail=0)
# 遍历所有图片并识别文字,切片提取有效信息
data = []
for image in os.listdir(images):content = ocr.readtext(f'{images}/{image}', detail=0)print(f"正在识别:{image}")name = content[0][4:]gender = content[1][-1]nation = content[2][-1]birth = content[-5]if "月" not in birth:birth = content[-6] + "月" + content[-5]if "日" not in birth:birth = birth[:-1] + "日"address = content[-4][4:] + content[-3]number = content[-1]print(f"完成识别:{image}")print("-" * 50)data.append([name, gender, nation, birth, address, number])

4.保存数据

图片文字识别之后,建议通过pandas输出为Excel,方便简洁。

'''
公众号:菜J学Python
作者:J哥
'''import pandas as pd# 保存识别结果至Excel
df = pd.DataFrame(data, columns=["姓名", "性别", "民族", "出生", "住址", "身份证号"])
print(f"识别结果如下:")
print(df)
df.to_excel("识别结果.xlsx", index=False)

以上。

END -

对比Excel系列图书累积销量达15w册,让你轻松掌握数据分析技能,可以点击下方链接进行了解选购:

批量识别图片文字并存为Excel,几行Python轻松实现!相关推荐

  1. Python自动化办公:批量识别图片文字并存为Excel

    来源:菜J学Python 一.背景 也许你还记得,前不久复旦大学一博士生写了130行Python代码,批量识别核酸截图内容的故事.当时还被人民日报公众号报道出来,夸赞用所学贡献青春力量! 其实,批量文 ...

  2. python实现批量识别图片文字,生成对应的txt文件

    目录 百度api 百度api 第一步:打开网站 https://ai.baidu.com/ 第二步:注册登录 第三步: 登录成功,直接输入这个 https://console.bce.baidu.co ...

  3. 单张、批量识别图片中文字(写入txt文件、窗口视图创建、打包.exe文件)(百度文字识别SDK+Python的GUI之tklinker+打包pyinstaller)

    昨天我姐问我有没有软件可以批量识别图片上的文字,她在帮客户做资料整理,但是用的方法只能一张一张上传识别,不仅效率低还浪费时间. ​我就找了找批量识别的软件,下载下来觉得:嗯?不错,界面也挺好,小东西做 ...

  4. python批量识别图片中文字_利用Python批量进行图片文字识别

    实现逻辑 1. 批量获取图片的路径 2. 通过调用百度OCR接口批量识别图片 3. 将返回值写入txt 实现过程 1. 安装百度的Python SDK pip install baidu-aip 2. ...

  5. python识别图片指定位置文字_python批量识别图片指定区域文字内容

    Python批量识别图片指定区域文字内容,供大家参考,具体内容如下 简介 对于一张图片,需求识别指定区域的内容 1.截取原始图上的指定图片当做模板 2.根据模板相似度去再原始图片上识别准确坐标 3.根 ...

  6. python 制定识别图片的某些区域_python批量识别图片指定区域文字内容

    Python批量识别图片指定区域文字内容,供大家参考,具体内容如下 简介 对于一张图片,需求识别指定区域的内容 1.截取原始图上的指定图片当做模板 2.根据模板相似度去再原始图片上识别准确坐标 3.根 ...

  7. python批量图片文字识别_利用Python批量进行图片文字识别

    实现逻辑 1. 批量获取图片的路径 2. 通过调用百度OCR接口批量识别图片 3. 将返回值写入txt 实现过程 1. 安装百度的Python SDK pip install baidu-aip 2. ...

  8. Excel快速清晰的识别图片文字为可编辑文字

    今天我和大家分享的是,Excel也可以快速清晰的识别图片文字为可编辑文字,详见下面的动图演示. (方方格子插件.) 1.首先打开表格.然后看到表格当中有一段图片的文字,选中将其复制. 2.选择DIY工 ...

  9. [软件工具]OCR批量识别图片提取文字信息提取号码编号单号软件使用教程

    当你有很多图片,但是想提取这些图片里面的手机号或者编号或者快递单号,或者是其他一些信息时候这个工具就很有用了,一般都是通过打开图片一张一张去查看手动输入信息,但是图片很多时候基本就是个体力活,十分不方 ...

最新文章

  1. 军转干部计算机测试题,2015福建军转干考试计算机基础知识:计算机网络
  2. android 第三方登录界面,Android App集成第三方登录与换肤指南
  3. jdk open jdk_JDK 14的迹象开始出现
  4. python-类的定制
  5. 城市发展规律及未来走向进行认知与预测的机构
  6. 数据库课程设计——学生选课管理系统
  7. ArcGIS下载在线地图影像上篇(手工版)
  8. mistake - pwnable
  9. 网络连接正常,浏览器确没有网?
  10. 第一性原理:戳中问题本质的人是怎么思考的?
  11. 中央电大 c语言程序设计a 试题,中央电大208年秋C语言程序设计A试题1.doc
  12. pycharm中Crtl+Shift+F10快捷键问题
  13. QT实现图片的滚轮缩放、框选放大、拖拽移动
  14. 正大国际期货:什么是黄金保证金交易?黄金保证金交易包含哪些要点?
  15. 公司申请微信订阅号需要的材料及注意事项
  16. java中虚函数_虚函数
  17. 9个宝藏级的神奇网站!个个精品,让你人生开挂,效率翻倍
  18. 高校bbs或者科研论坛
  19. debian重启ssh服务_EUserv 德国永久免费VPS申请,仅有IPv6网络 另附IPv6服务器建站教程...
  20. Unity_画线_地面画框_类似汽车停车位_拖尾组件Trail Renderer_Demo

热门文章

  1. 濒死状态下的静息态网络激活和功能连接
  2. matlab计算一组数的函数值_matlab中怎么求一组数据概率最大的数
  3. 我的世界服务器修改npc指令,我的世界自定义npc指令 | 手游网游页游攻略大全
  4. CDN加速全站配置教程
  5. H5浏览器下无插件、低延时、RTSP视频流直播
  6. 猿辅导python编程老师面试_猿辅导辅导老师面试过程➕感受
  7. L2-003. 月饼
  8. 为什么建议选英文技术书籍
  9. 如何从一根普通八芯网线如何分出电话线和网络线?
  10. wps透视表列总计移到顶部_数据透视表总计中的错误