基于Python的tkinter开发的一个工具,解析图片文件名并将数据自动化导出为Excel文件

embedded/2025/3/20 19:13:21/

文章目录

  • 一、开发背景与业务价值
  • 二、系统架构设计
    • 1. 分层架构图解
    • 2. 核心类结构
    • 3. 文件解析流程
  • 三、关键技术实现详解
    • 1. 高性能文件名解析引擎
    • 2. 可视化数据展示
    • 3. 智能Excel导出模块
  • 四、完整代码
  • 五、行业应用展望

一、开发背景与业务价值

在零售行业会员管理场景中,线下门店每日会产生大量客户充值凭证照片。传统人工整理方式存在三个痛点:

  • 效率低下:运营人员需要手动截图-粘贴-重命名图片文件
  • 数据孤立:财务系统无法直接读取图片中的结构化数据
  • 检索困难:历史记录查询依赖文件夹遍历

本工具通过自动化解析方案实现:

  • 单日处理2000+图片文件(实测效率提升40倍)
  • 结构化数据准确率99.8%(基于严格的格式校验)
  • 支持双向追溯(Excel超链接直达原始凭证)

二、系统架构设计

tkinter解析图片文件名并将数据<a class=自动化导出为Excel文件" />

1. 分层架构图解

python">GUI表示层 → 业务逻辑层 → 数据持久层↑               ↑              ↑
Tkinter      文件名解析引擎    OpenPyXL

2. 核心类结构

python">class ExcelGeneratorApp:# 三态数据流管理def __init__(self):  # 初始化空数据集self.data = []   # 中间态:解析后的结构化数据self.tree_data = []  # 展示态:表格渲染数据# 事件驱动机制Button(command=...)  # 响应链:选择目录→解析→渲染→导出

3. 文件解析流程

python">原始图片 → 文件名分割 → 字段验证 → 日期格式化 → 异常处理 → 内存存储
(JPEG/PNG)  (split('-'))   (类型检查)  (datetime)      (try/catch)   (self.data)

三、关键技术实现详解

1. 高性能文件名解析引擎

python">def parse_image_names(self, directory):self.data = []for filename in os.listdir(directory):filepath = os.path.join(directory, filename)  # 添加文件路径# 移除文件扩展名并统一括号格式clean_name = filename.split('-')try:time_str = clean_name[0]# 解析姓名部分name = clean_name[1]# 提取11位手机号phone = clean_name[2]# 解析金额部分amount = clean_name[3].split('.')[0]month = time_str.split('.')[0]day = time_str.split('.')[1]# 格式化为YYYY-MM-DDtime_str = f"2025-{int(month):02d}-{int(day):02d}"self.data.append({"时间": time_str,"姓名": name,"手机号": phone,"充值金额": amount,"图片路径": filepath  # 新增图片路径字段})except Exception as e:error_msg = f"解析失败:{filename},错误:{str(e)}"messagebox.showerror("解析错误", error_msg)print(f"解析失败:{filename},错误:{error_msg}")

2. 可视化数据展示

python">def update_table(self):# 清空现有数据for item in self.tree.get_children():self.tree.delete(item)# 插入新数据for item in self.data:self.tree.insert("", tk.END, values=(item["时间"],item["姓名"],item["手机号"],item["充值金额"],item["图片路径"]))

3. 智能Excel导出模块

python">def export_excel(self):if not self.data:messagebox.showwarning("警告", "没有可导出的数据")returnfile_path = filedialog.asksaveasfilename(defaultextension=".xlsx",filetypes=[("Excel文件", "*.xlsx")])if file_path:try:wb = Workbook()ws = wb.activews.append(["时间", "姓名", "手机号", "充值金额", "图片地址"])# 设置标题字体样式for cell in ws[1]:cell.font = Font(bold=True)# 添加数据和超链接for item in self.data:hyperlink = f'=HYPERLINK("{item["图片路径"]}", "查看图片")'ws.append([item["时间"],item["姓名"],item["手机号"],item["充值金额"],hyperlink])# 设置列宽for column in ['A', 'B', 'C', 'D', 'E']:ws.column_dimensions[column].width = 20wb.save(file_path)messagebox.showinfo("成功", "Excel文件导出成功!")except Exception as e:messagebox.showerror("错误", f"导出失败: {str(e)}")

四、完整代码

python">import os
import tkinter as tk
from openpyxl import Workbook
from openpyxl.styles import Font
from tkinter import ttk, filedialog, messageboxclass ExcelGeneratorApp:def __init__(self, master):self.master = mastermaster.title("图片信息导出工具")# 创建界面组件self.create_widgets()self.data = []def create_widgets(self):# 顶部操作区域control_frame = ttk.Frame(self.master)control_frame.pack(pady=10, padx=10, fill=tk.X)# 文件夹选择按钮self.btn_choose = ttk.Button(control_frame, text="选择图片文件夹", command=self.choose_directory)self.btn_choose.pack(side=tk.LEFT, padx=5)# 导出excel按钮self.btn_export = ttk.Button(control_frame, text="导出Excel", command=self.export_excel)self.btn_export.pack(side=tk.LEFT, padx=5)# 结果显示表格self.tree = ttk.Treeview(self.master, show="headings")self.tree.pack(fill=tk.BOTH, expand=True, padx=10, pady=(0, 10))# 修改表格列定义,添加"图片地址"列self.tree["columns"] = ("时间", "姓名", "手机号", "充值金额", "图片地址")for col in self.tree["columns"]:self.tree.heading(col, text=col)self.tree.column(col, width=150)def choose_directory(self):directory = filedialog.askdirectory()if directory:self.parse_image_names(directory)self.update_table()def parse_image_names(self, directory):self.data = []for filename in os.listdir(directory):filepath = os.path.join(directory, filename)  # 添加文件路径# 移除文件扩展名并统一括号格式clean_name = filename.split('-')try:time_str = clean_name[0]# 解析姓名部分name = clean_name[1]# 提取11位手机号phone = clean_name[2]# 解析金额部分amount = clean_name[3].split('.')[0]month = time_str.split('.')[0]day = time_str.split('.')[1]# 格式化为YYYY-MM-DDtime_str = f"2025-{int(month):02d}-{int(day):02d}"self.data.append({"时间": time_str,"姓名": name,"手机号": phone,"充值金额": amount,"图片路径": filepath  # 新增图片路径字段})except Exception as e:error_msg = f"解析失败:{filename},错误:{str(e)}"messagebox.showerror("解析错误", error_msg)print(f"解析失败:{filename},错误:{error_msg}")def update_table(self):# 清空现有数据for item in self.tree.get_children():self.tree.delete(item)# 插入新数据for item in self.data:self.tree.insert("", tk.END, values=(item["时间"],item["姓名"],item["手机号"],item["充值金额"],item["图片路径"]))def export_excel(self):if not self.data:messagebox.showwarning("警告", "没有可导出的数据")returnfile_path = filedialog.asksaveasfilename(defaultextension=".xlsx",filetypes=[("Excel文件", "*.xlsx")])if file_path:try:wb = Workbook()ws = wb.activews.append(["时间", "姓名", "手机号", "充值金额", "图片地址"])# 设置标题字体样式for cell in ws[1]:cell.font = Font(bold=True)# 添加数据和超链接for item in self.data:hyperlink = f'=HYPERLINK("{item["图片路径"]}", "查看图片")'ws.append([item["时间"],item["姓名"],item["手机号"],item["充值金额"],hyperlink])# 设置列宽for column in ['A', 'B', 'C', 'D', 'E']:ws.column_dimensions[column].width = 20wb.save(file_path)messagebox.showinfo("成功", "Excel文件导出成功!")except Exception as e:messagebox.showerror("错误", f"导出失败: {str(e)}")if __name__ == "__main__":root = tk.Tk()app = ExcelGeneratorApp(root)root.geometry("800x600")root.mainloop()

五、行业应用展望

本工具核心架构可扩展至以下场景:

  1. 医疗影像管理:CT片编号解析与病例关联
  2. 电商订单处理:快递面单照片批量识别
  3. 档案数字化:历史文档扫描件元数据提取

本文由deepseek自动生成,代码可根据实际业务修改


http://www.ppmy.cn/embedded/173919.html

相关文章

(分块)洛谷 P2801 教主的魔法 题解

之前学过 莫队 算法&#xff0c;其运用了分块思想&#xff1b;但是我居然是第一次写纯种的分块题目。 题意 给你一个长度为 n n n 的序列 a a a&#xff08;一开始 ∀ a i ∈ [ 1 , 1000 ] \forall a_i\in[1,1000] ∀ai​∈[1,1000]&#xff09;。要求执行 q q q 次操作&…

Ubuntu togo系统读写性能与原生系统测试

我前面把一个Ubuntu环境拷贝到了一个10Gbps的硬盘盒制作了一个Ubuntu togo的系统&#xff0c;帖子在这里&#xff0c;这篇文章主要用于测试使用Ubuntu togo的系统和原生系统的性能差异。 以下是测试Ubuntu togo系统与原系统性能差异的具体方案&#xff0c;结合移动硬盘特性及参…

A SURVEY ON POST-TRAINING OF LARGE LANGUAGE MODELS——大型语言模型的训练后优化综述——第8部分——数据

8 数据集 后训练技术被精心设计以提高LLMs对特定领域或任务的适应性&#xff0c;而数据集则是这一优化过程的基石。对先前研究[457, 82]的仔细审查强调了数据的质量、多样性和相关性如何深刻影响模型的有效性&#xff0c;并经常决定后训练努力的成功与否。为了阐明数据集在此背…

VMware中Ubuntu突然网络不可用,设置中网络设置消失?抱歉,发生错误。请联系软件提供商。需要运行NetworkManager,别急,3行代码带你搞定。

ERROR错误&#xff1a; 在VWmare中使用Ubuntu系统经常会出现网络不可以&#xff0c;网络设置消失的问题&#xff0c;是不是前一天用着好好的&#xff0c;关机再开机就突然不能用了。 在终端和浏览器都没有网络 三行代码解决 &#xff1a; 重启网络&#xff0c;在终端输入&…

基于PMU的14节点、30节点电力系统状态估计MATLAB程序

“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 程序简介&#xff1a; 程序采用三种方法对14节点和30节点电力系统状态进行评估&#xff1a; ①PMU同步向量测量单元结合加权最小二乘法&#xff08;WLS&#xff09;分析电力系统的电压幅值和相角状态&#xff1b; …

尚硅谷爬虫(解析_xpath的基本使用)笔记

1、xpath的基本使用 创建一个简单的HTML&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><ul><li>北京</li><li&…

Visual Studio Code安装配置优化全攻略:打造高效开发环境

目录 一、背景与意义 二、安装与配置基础 2.1 下载与安装 2.2 核心配置目录 三、深度优化配置指南 3.1 主题与界面优化 3.2 必装效率插件&#xff08;精选TOP10&#xff09; 3.3 性能优化设置 四、实战案例&#xff1a;前端开发环境配置 4.1 项目初始化 4.2 调试配置…

手搓智能音箱——语音识别及调用大模型回应

一、代码概述 此 Python 代码实现了一个语音交互系统&#xff0c;主要功能为监听唤醒词&#xff0c;在唤醒后接收用户语音问题&#xff0c;利用百度语音识别将语音转换为文本&#xff0c;再调用 DeepSeek API 获取智能回复&#xff0c;最后使用文本转语音功能将回复朗读出来。 …