Python语言开发应用之Python 批量读取身份证信息写入 Excel
小职 2021-07-08 来源 :Python小二 阅读 1458 评论 0

摘要:本文主要介绍了Python语言开发应用之Python 批量读取身份证信息写入 Excel,通过具体的内容向大家展现,希望对大家Python程序开发的学习有所帮助。

本文主要介绍了Python语言开发应用之Python 批量读取身份证信息写入 Excel,通过具体的内容向大家展现,希望对大家Python程序开发的学习有所帮助。

Python语言开发应用之Python 批量读取身份证信息写入 Excel

今天分享一个实用技能,利用 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,登录后将鼠标移到登录头像位置,在弹出菜单中点击用户中心,如图所示:

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

选完之后点保存即可。

 

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

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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

 

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

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

 

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

 

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

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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

 

代码实现

 

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

 

from aip import AipOcr

 

APP_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)  # 高精度

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

 

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

 Python语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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

 

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语言开发应用之Python 批量读取身份证信息写入 Excel

 

 

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


我是小职,记得找我

✅ 解锁高薪工作

✅ 免费获取基础课程·答疑解惑·职业测评

Python语言开发应用之Python 批量读取身份证信息写入 Excel

本文由 @小职 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved