IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 自动化神器!Python 批量读取身份证信息写入 Excel -> 正文阅读

[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,登录后将鼠标移到登录头像位置,在弹出菜单中点击用户中心,如图所示:

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

选完之后点保存即可。

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

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

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

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

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

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

我们需要用到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)  # 高精度

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

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

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

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知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-07-05 20:19:50  更:2021-07-05 20:19:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/14 14:35:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码