用Python制作可视化GUI界面,一键提取图片当中的数据并保存至Excel当中

发布时间:2024-12-11 15:01

也就在前不久,复旦大学一博士生写了130行Python代码,批量识别核酸截图的故事,被人民日报公众号广泛报道,夸赞其将所学之知识技术应用到实际生活当中,大大减少了人力的投入,提高了效率。当中用到了OCR的技术来识别图表当中的数据,同时对于不懂技术的童鞋来来说不懂如何去操作,因此今天小编制作了一个UI界面来自动化一键提取图片当中的数据。

要想获取本教程部分源码,可在公众号后台回复【20220706

安装模块

首先我们需要安装easyocr模块,通过pip命令

pip install easyocr

而用来制作UI界面的框架小编选择的是PyQt框架,因为它支持手动绘制控件,并且可以动态加载,我们在Pycharm当中添加上QtDesigner作为外部工具,来进行界面设置,生成ui文件,步骤如下

用Python制作可视化GUI界面,一键提取图片当中的数据并保存至Excel当中_第1张图片

在一系列的配置完成之后,我们打开QtDesigner的初始界面,整体的过程就是将我们需要的控件拖到界面当中即可,

用Python制作可视化GUI界面,一键提取图片当中的数据并保存至Excel当中_第2张图片

我们希望最后呈现出来的功能是在上传图片之后,点击“开始提取数据”按钮,后端的代码可以见上传的图片中的数据识别出来,并且将数据保存到Excel当中下载至桌面上,在程序运行结束之后,会弹出提示框提示结束。因此UI界面的设计如下

用Python制作可视化GUI界面,一键提取图片当中的数据并保存至Excel当中_第3张图片

代码逻辑

当我们点击“选择图片”实现图片上传的功能,代码如下

# 选择本地图片上传
def uploadImages(self):
    global imgNamepath_list  # 这里为了方便别的地方引用图片路径,将其设置为全局变量
    # 弹出一个文件选择框,第一个返回值imgName记录选中的文件路径+文件名,第二个返回值imgType记录文件的类型
    # QFileDialog就是系统对话框的那个类第一个参数是上下文,第二个参数是弹框的名字,第三个参数是默认打开的路径,第四个参数是需要的格式
    imgNamepath_list, imgType = QFileDialog.getOpenFileNames(self.ui, "上传文件", r"C:\Users", "*.png;;*.jpg;;All Files(*)")
    # print("imgNamepath_list: ", imgNamepath_list)
    # 显示所选图片的路径
    self.ui.lineEdit.setText(",".join(imgNamepath_list))

我们会将图片的路径悉数打印出来在文本框内,而当我们点击“开始”按钮的时候便尝试将上传的图片中的数据提取出来,上传的图片如下所示

用Python制作可视化GUI界面,一键提取图片当中的数据并保存至Excel当中_第4张图片

我们需要提取出来的是姓名、出生年月、住址信息等等,代码如下

data = []
for imgNamepath in imgNamepath_list:
    content = ocr.readtext(f'{imgNamepath}', detail=0)
    print(f"正在识别:{imgNamepath}")
    name = content[0][4:]
    gender = content[1][-1]
    country = content[2][-1]
    date_of_birth = content[-5]
    address = content[-4][4:] + content[-3]
    id_number = content[-1]
    data.append([name, gender, country, date_of_birth, address, id_number])

最后我们将数据保存到Excel表格当中并且放置在桌面上,代码如下

df = pd.DataFrame(data, columns=["姓名", "性别", "民族", "出生", "住址", "身份证号"])
df.to_excel(r"C:\Users\PC120\Desktop\识别结果.xlsx", index=False)

当所有任务都完成的时候,会弹出提示框出来,提示任务已经完成了,代码如下

msg_box = QMessageBox(QMessageBox.Information, '完成', '提取完成', QMessageBox.Yes)
msg_box.exec_()

最后我们来看一下最后的效果

NO.1

往期推荐

Historical articles

【硬核干货】数据分析哪家强?选Pandas还是选SQL

【硬核原创】盘点Python爬虫中的常见加密算法,建议收藏!!

Python 办公自动化之全网最强最详细PDF 文件操作手册

Python实现定时任务的八种方案,干货满满

分享、收藏、点赞、在看安排一下?

64e40b7fcb36a6f25b11d65e91fb8bfa.gif

2f47073ccf92e85485ed1a1168641bab.gif

2cf9c3ad241fe6d9c5cd037293b58c9b.gif

742a0ef52b90b559474cc11e71fe87ba.gif

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号