文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python如何实现批量识别图片文字并存为Excel

2023-07-02 00:13

关注

今天小编给大家分享一下Python如何实现批量识别图片文字并存为Excel的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、背景

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

PythonOCR第三方库非常多,比如easyocrPaddleOCRcnocr等等。

二、需求

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

Python如何实现批量识别图片文字并存为Excel

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

Python如何实现批量识别图片文字并存为Excel

三、实战

1.安装模块

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

pip install easyocr

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

2.识别一张图片

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

调用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 easyocrimage = './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 easyocrimport 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# 保存识别结果至Exceldf = pd.DataFrame(data, columns=["姓名", "性别", "民族", "出生", "住址", "身份证号"])print(f"识别结果如下:")print(df)df.to_excel("识别结果.xlsx", index=False)

以上就是“Python如何实现批量识别图片文字并存为Excel”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯