Python自动化办公:批量识别图片文字并存为Excel
来源:菜J学Python
一、背景
也许你还记得,前不久复旦大学一博士生写了130行Python
代码,批量识别核酸截图内容的故事。当时还被人民日报公众号报道出来,夸赞用所学贡献青春力量!
其实,批量文字识别(OCR)是Python
办公自动化的基本操作,应用在我们工作生活中的方方面面,比如车牌识别、证件识别、银行卡识别、票据识别等等。
Python
中OCR
第三方库非常多,比如easyocr
、PaddleOCR
、cnocr
等等。当然,直接调用百度API
也是可以的,不过超过一定限额后要收费,因此本文主要以开源免费的easyocr
来进行介绍。
二、需求
本文以证件识别为例,我网上找了3张虚拟身份证来实验:
运用easyocr
进行识别并保存为Excel
,效果如下:
三、实战
1.安装模块
在Python
中使用 easyocr
非常简单,只要使用pip
命令安装easyocr
即可(建议使用清华源,否则安装会比较慢)。
pip install easyocr
不过 easyocr
的深度学习算法依赖于另一个著名的第三方模块 pytorch
,图形处理部分则会用到 opencv
、Pillow
等,所以还需要确保自己电脑上已经安装这些基础模块。
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 --------
精选资料回复关键词,获取对应的资料:
关键词资料名称600《Python知识手册》md《Markdown速查表》time《Python时间使用指南》str《Python字符串速查表》pip《Python:Pip速查表》style《Pandas表格样式配置指南》mat《Matplotlib入门100个案例》px《Plotly Express可视化指南》精选内容数据科学: VS Code 中 Python配置使用指南 | 财经工具 Tushare | Matplotlib 最有价值的 50 个图表
书籍阅读: 如何阅读一本书 | 巴菲特之道 | 价值 | 原则 | 投资最重要的事 | 戴维斯王朝 | 客户的游艇在哪里 | 刻意练习 | 林肯传 | 金字塔原理
投资小结: 2021Q4 | 2021Q3 | 2021Q2 | 2021Q1 | 2020Q4
精选视频可视化: Plotly Express
财经: Plotly在投资领域的应用 | 绘制K线图表
排序算法: 汇总 | 冒泡排序 | 选择排序 | 快速排序 | 归并排序 | 堆排序 | 插入排序 | 希尔排序 | 计数排序 | 桶排序 | 基数排序
Python自动化办公:批量识别图片文字并存为Excel相关推荐
- 批量识别图片文字并存为Excel,几行Python轻松实现!
今天给大家分享批量识别图片的方法. 一.背景 也许你还记得,前不久复旦大学一博士生写了130行Python代码,批量识别核酸截图内容的故事.当时还被人民日报公众号报道出来,夸赞用所学贡献青春力量! 其 ...
- python学习使用easyocr识别图片文字
测试了C#中调用PaddleOCRSharp和PaddleSharp进行图片文字识别,由于正在学习python,也就同时学习使用python进行图片文字识别的方法. 百度关键词"py ...
- python实现批量识别图片文字,生成对应的txt文件
目录 百度api 百度api 第一步:打开网站 https://ai.baidu.com/ 第二步:注册登录 第三步: 登录成功,直接输入这个 https://console.bce.baidu.co ...
- python 批量移动文件_[Python] 自动化办公 批量命名和移动文件
转载请注明:陈熹 chenx6542@foxmail.com (简书号:半为花间酒) 若公众号内转载请联系公众号:早起Python 这篇文章能学到的主要内容: 基于 os glob 和 shutil ...
- python自动化办公 51cto_Python办公自动化之从Word到Excel
大家好,今天有一个公务员的小伙伴委托我给他帮个忙,大概是有这样一份Word(由于涉及文件私密所以文中的具体内容已做修改) 一共有近2600条类似格式的表格细栏,每个栏目包括的信息有: 日期 发文单位 ...
- 单张、批量识别图片中文字(写入txt文件、窗口视图创建、打包.exe文件)(百度文字识别SDK+Python的GUI之tklinker+打包pyinstaller)
昨天我姐问我有没有软件可以批量识别图片上的文字,她在帮客户做资料整理,但是用的方法只能一张一张上传识别,不仅效率低还浪费时间. 我就找了找批量识别的软件,下载下来觉得:嗯?不错,界面也挺好,小东西做 ...
- 百度AI识别图片文字
判断图片格式,转换为Jpg格式,为图片文字识别做准备 # !/usr/bin/env python # -*- coding: utf-8 -*- # 转换图片格式为jpg格式import os fr ...
- python批量识别图片中文字_利用Python批量进行图片文字识别
实现逻辑 1. 批量获取图片的路径 2. 通过调用百度OCR接口批量识别图片 3. 将返回值写入txt 实现过程 1. 安装百度的Python SDK pip install baidu-aip 2. ...
- python识别图片指定位置文字_python批量识别图片指定区域文字内容
Python批量识别图片指定区域文字内容,供大家参考,具体内容如下 简介 对于一张图片,需求识别指定区域的内容 1.截取原始图上的指定图片当做模板 2.根据模板相似度去再原始图片上识别准确坐标 3.根 ...
最新文章
- linux运维人员必会运维工具
- python【蓝桥杯vip练习题库】ALGO-118连续正整数的和(枚举优化)
- 业务逻辑实现方式选择
- 中科微研课题上犹授牌-农业大健康·李喜贵:谋定功能性农业
- java toHalf_MoreThanHalfInArray.java
- 视频会议H.323协议SIP协议
- 写在前面,白话 Yaf 探秘与深入
- php判断外链,php检查字符串中是否有外链的方法
- 12款白帽子用于黑客渗透测试的操作系统
- CTS(23) --- Android 8.1GMS注意事项
- iOS开发拓展篇—音频处理(音乐播放器3)
- 面向对象下计算器的编码实现
- EO CAT软件下载数据
- matlab中abs函数,Abs函数
- 网络抖动多少ms算正常_网络延迟多少ms正常 - 卡饭网
- 将Unity地形以Wavefront Obj格式导出
- Python国际象棋棋盘绘制
- 海量数据处理算法 各种STL容器使用的数据结构剖析
- 工作流Activiti初体验—流程撤回【二】
- YTU 2325 查找【数组】