自动化神器!Python 批量读取身份证信息写入 Excel

article/2025/9/27 8:28:23

今天分享一个实用技能,利用 Python 批量读取身份证信息写入 Excel。

读取

以图片形式的身份证为例,信息读取我们使用百度文字识别OCR来实现,百度接口提供了免费额度,日常使用基本差不多够了,下面来具体看一下如何使用百度文字识别。

SDK 安装

百度云 SDK 提供了 Python、Java 等多种语言的支持,Python 版的 SDK 安装很简单,使用pip install baidu-aip即可,支持 Python 2.7+ & 3.x 版本。

创建应用

创建应用需要一个百度或百度云账号,注册登录地址为:https://login.bce.baidu.com/?redirect=http%3A%2F%2Fcloud.baidu.com%2Fcampaign%2Fcampus-2018%2Findex.html,登录后将鼠标移到登录头像位置,在弹出菜单中点击用户中心,如图所示:

首次进入需选一下相应信息,如图所示:

选完之后点保存即可。

接着将鼠标移到左侧>符号位置,再选人工智能,点击文字识别,如图所示:

点击之后会进到如下所示图中:

现在,我们就可以点击创建应用了,之后进到如下所示图中:

从上图中我们可以看出百度文字识别OCR能够识别的信息类别非常多,也就是说不只是身份证,如果你有其他信息识别的需求也是可以通过它来快速实现的。

这里我们填一下应用名称应用描述,填完之后点立即创建即可。

创建完成后返回应用列表,如下图所示:

我们需要用到AppID&API Key&Secret Key这三个值,记录一下。

代码实现

代码实现很简单,几行 Python 代码即可搞定,如下所示:

from aip import AipOcrAPP_ID = '自己的APP_ID'
API_KEY = '自己的API_KEY'
SECRET_KEY = '自己的SECRET_KEY'
# 创建客户端对象
client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
# 打开并读取文件内容
fp = open("idcard.jpg", "rb").read()
# res = client.basicGeneral(fp)  # 普通
res = client.basicAccurate(fp)  # 高精度

从上述代码中可以看出识别功能分为普通高精度两种模式,为了识别率更高,我们这里采用高精度模式。

以如下三张我在网上找的假身份证为例:

因为有多张身份证图片,我们需要写一个方法来进行遍历,代码实现如下:

def findAllFile(base):for root, ds, fs in os.walk(base):for f in fs:yield base + f

通过识别功能获取到的身份证原始信息格式如下:

{'words_result': [{'words': '姓名韦小宝'}, {'words': '性别男民族汉'}, {'words': '出生1654年12月20日'}, {'words': '住址北京市东城区景山前街4号'}, {'words': '紫禁城敬事房'}, {'words': '公民身份证号码11204416541220243X'}], 'log_id': 1411522933129289151, 'words_result_num': 6}

写入

证件信息的写入使用 Pandas 来实现。这里我们还需要先将获取的原始证件信息进行预处理以便写入 Excel 中,我们将证件的姓名…住址分别存放在数组中,处理代码实现如下:

for tex in res["words_result"]:row = tex["words"]if "姓名" in row:names.append(row[2:])elif "性别" in row:genders.append(row[2:3])nations.append(row[5:])elif "出生" in row:births.append(row[2:])elif "住址" in row:addr += row[2:]elif "公民身份证号码" in row:ids.append(row[7:])else:addr += row

之后就可以很方便的将信息直接写入到 Excel 中了,写入代码实现如下:

df = pd.DataFrame({"姓名": names, "性别": genders, "民族": nations,"出生": births, "住址": address, "身份证号码": ids})
df.to_excel('idcards.xlsx', index=False)

看一下写入效果:

到此,我们就实现了身份证信息的批量读写功能。

源码在公众号Python小二后台回复身份证获取。


http://chatgpt.dhexx.cn/article/I2wWmBBm.shtml

相关文章

浏览器使用华视电子设备读取身份证信息

项目中用到了使用华视电子CVR-100U、CVR-100D设备读取身份证的设备在浏览器上读取身份证信息,在浏览器使用时,需要安装浏览器的运行的插件,否则设备不好用。 sdk下载方式在文章最后 此控件支持IE、360浏览器、360极速浏览器等浏览器 暂不支持…

身份证读取设备开发解决方案:3、单片机读取身份证信息的demo

身份证读取设备开发解决方案:3、单片机读取身份证信息的demo 文章目录 身份证读取设备开发解决方案:3、单片机读取身份证信息的demo一、前言二、部分代码及结果展示1. 准备2. 部分代码3. 结果展示 三、常见错误错误1错误2 四、注意事项1. 确认串口线焊接…

身份证阅读器读卡器React网页方法实现身份证的读取

支持产品型号东信EST-100GS谷歌版本身份证读卡器USB免驱接口,支持谷歌火狐360 IE 遨游 搜狗 等等多种web浏览器使用。 官方网址:www.eastcoms.com 以下为React源码示例: import React, {PureComponent} from react; import "./agreemen…

身份证读取

在找读取身份证动态库(dll) 文件时,发现这么一篇好文章,有兴趣学习一下! ---------------- 这份代码,主要是根据api文档来写的,文档上提供了各个方法的使用说明,并且有一个示例代码。…

身份证读取设备开发解决方案:1、Windows下开发Qt程序demo读取身份证信息

身份证读取设备开发解决方案:1、Windows下开发Qt程序demo读取身份证信息 文章目录 身份证读取设备开发解决方案:1、Windows下开发Qt程序demo读取身份证信息1. 前言2. 身份证读取模块3. Qt5开发简单上位机读取身份证信息1. 注意的点2. 部分源码3. 结果展示…

最新web/java/jsp实现发送手机短信验证码和邮箱验证码的注册登录功能(详细)

最新web/java/jsp实现发送手机短信验证码和邮箱验证码的注册登录功能(详细) 最近几天有人需要帮忙做一个关于发送验证码的功能,之前没有做过,于是我鼓捣一阵子,记录一下关于web项目中注册登录常用的手机验证码和邮箱验…

uniapp中注册手机号短信验证码

一、效果图 二、输入手机号页面 <template><view><view classlogin-tel><view classtel-main><view classlogin-from><view classlogin-user><text classuser-text>手机号</text><input type"number" focustrue…

阿里云手机验证码注册(可以使用阿里云提供的测试模板,不用个人申请)

目录 打开阿里云&#xff1a;&#xff08;绑定手机号码&#xff09;&#xff0c;不用申请模板和签名手机验证码注册流程&#xff1a;实现流程创建springboot工程&#xff0c;添加依赖编写applicatioin配置文件编写controller&#xff0c;根据手机号发送短信编写service&#xf…

抖音实战~手机号验证码一键注册登录流程(限制手机终端登录)

文章目录 一、手机号验证码二、前端2.1. 点击登陆流程2.2. 点击登录源码 三、后端登录3.1. 登录流程图3.2. 流程简述3.3. 手机号验证码登录流程 一、手机号验证码 二、前端 2.1. 点击登陆流程 1.先校验手机号是否合法&#xff1f;不合法&#xff0c;则提示“请输入正确的手机…

会话——验证码注册与记住密码登录

文章目录 1、需求分析2、用户登录功能2.1、流程分析2.2、代码实现2.3、结果演示 3、登录记住密码功能3.1、流程分析3.2、代码实现3.3、结果演示 4、用户注册功能4.1、流程分析4.2、代码实现4.3、结果演示 5、注册验证码功能5.1、流程分析5.2、代码实现5.3、结果演示 1、需求分析…

关于烧写ESP8285核心板的相关事项

首先需要一个CH340的usb 转ttl 板子 然后连接到8285 脚管对应 TTL ---- 8285 VCC----VCC RXD----TX0 TXD----RX0 GND----GND 在通电之前先要把8285的GND 和io 0 连在ttl 板子的 GND上 烧写软件要设置正确否则无法启动

esp32 esp8285 wf6000OTA升级小记

近期做了3个IOT芯片的OTA升级&#xff0c;记录下&#xff1a; 最开始做完的是ESP32,升级流程也简单&#xff0c;初始烧录到固定区&#xff0c;然后OTA升级就会在user1,user2两个区内来回升&#xff0c;升级的文件是同一个&#xff08;即同一个文件&#xff0c;先升级就是user1…

Ubuntu18.04 上 ESP8285 的 esp-at release_v2.2.0.0 编译环境搭建

1 环境搭建前提 1.1 安装编译 ESP-IDF 需要的软件包&#xff1a; sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util1.2 安装 Python 3.8 sudo apt-get install python3.8-…

探索ESP8285(3)通过EMQX服务器点亮一个LED灯

CCC_122&#xff1a;博客只用于学习交流&#xff0c;不涉及任何商业用途&#xff0c;如果有错误之处&#xff0c;欢迎指正。 在上一个博客的基础上 探索ESP8285&#xff08;2&#xff09;搭建Windows版MQTT服务器 我们来通过EMQX服务器点亮ESP8285模块上的LED灯。 首先查得E…

乐鑫esp8266学习rtos3.0笔记第10篇:内置仅1M的Esp8285,如何攻破最棘手的OTA问题,大大节省资源成本开发产品;

本系列博客学习由非官方人员 半颗心脏 潜心所力所写&#xff0c;仅仅做个人技术交流分享&#xff0c;不做任何商业用途。如有不对之处&#xff0c;请留言&#xff0c;本人及时更改。 1、 Esp8266之 搭建开发环境&#xff0c;开始一个“hellow world”串口打印。 2、 Esp8266之…

晶科鑫 | 国产26MHz晶振匹配Espressif(乐鑫) ESP8285/ESP8266芯片案例

【应用】国产26MHz频率晶振应用于物联网WIFI物联网模块&#xff08;串口转WiFi模块&#xff09;&#xff0c;Espressif(乐鑫) ESP8285/ESP8266芯片匹配测试OK ESP8285其实是ESP8266的升级版本&#xff0c;两者可以共用同一套SDK&#xff0c;只是ESP8285内部集成了1MB Flash&…

ESP8285烧写问题备忘

1 问题现象 ESP8285 烧写了固件&#xff0c;怎么都跑不起来&#xff0c;串口打印如下信息&#xff1a; ets Jan 8 2013,rst cause:2, boot mode:(3,7)load 0x4010f000, len 1384, room 16 tail 8 chksum 0xef csum 0xef csum err ets_main.c 2 问题原因 上乐鑫官网查了 ESP…

ESP8285 多个bin文件合并烧录

可通过两种方式烧录固件&#xff0c;一种是基于esp-idf开发时&#xff0c;中命令终端执行make flash命令烧录&#xff1b;二是使用ESPFlashDownloadTool工具。 bin文件说明 ESP8285/ESP8266的固件一般包含4个bin文件。 查看各bin文件的路径 以带OTA的固件为例&#xff0c;在…

ESP8285+WS2812+MAX9814制作的音乐律动氛围灯

该项目主要参考了立创EDA开源广场的项目&#xff1a; esp8285芯片ESP-01F模块为主控&#xff0c;MAX9814音频采集模块&#xff0c;WS2812 2020rgb灯珠&#xff0c;Arduino编程环境简单制作一个律动灯条。 因为正在学习硬件PCB&#xff0c;所以只能算是一个仿照。 硬件&#x…

探索ESP8285(2)搭建Windows版MQTT服务器

CCC_122&#xff1a;博客只用于学习交流&#xff0c;不涉及任何商业用途&#xff0c;如果有错误之处&#xff0c;欢迎指正。 MQTT服务器有多个选择&#xff0c;例如EMQX&#xff0c;Mosquitto&#xff0c;Apollo&#xff0c;以下我们选择比较简单的EMQX来搭建MQTT的服务器。 一…