importtkinterastkfromtkinterimportttk,filedialog,messageboximportosclassImageNameExtractTool:def__init__(self,root):# 初始化主窗口self.root=root self.root.title("JPG/PNG图片文件名提取工具(输出TXT)")self.root.geometry("600x350")# 适配功能调整窗口大小# 定义变量存储文件夹路径和输出TXT文件路径self.source_folder=tk.StringVar()self.output_txt=tk.StringVar()# 创建界面控件self.create_widgets()defcreate_widgets(self):# 1. 源文件夹选择区域(存放JPG/PNG图片的文件夹)frame1=ttk.Frame(self.root,padding="20 10 20 10")frame1.pack(fill=tk.X,expand=False)ttk.Label(frame1,text="待提取图片的文件夹:").grid(row=0,column=0,sticky=tk.W,padx=5,pady=5)ttk.Entry(frame1,textvariable=self.source_folder,width=40).grid(row=0,column=1,padx=5,pady=5)ttk.Button(frame1,text="选择文件夹",command=self.select_source_folder).grid(row=0,column=2,padx=5,pady=5)# 2. 输出TXT文件选择区域frame2=ttk.Frame(self.root,padding="20 10 20 10")frame2.pack(fill=tk.X,expand=False)ttk.Label(frame2,text="提取后保存的TXT文件:").grid(row=0,column=0,sticky=tk.W,padx=5,pady=5)ttk.Entry(frame2,textvariable=self.output_txt,width=40).grid(row=0,column=1,padx=5,pady=5)ttk.Button(frame2,text="保存为",command=self.select_output_txt).grid(row=0,column=2,padx=5,pady=5)# 3. 提取按钮区域(核心操作按钮)frame3=ttk.Frame(self.root,padding="20 30 20 30")frame3.pack(fill=tk.BOTH,expand=True)self.extract_btn=ttk.Button(frame3,text="开始提取图片文件名",command=self.extract_image_names,style="Accent.TButton")self.extract_btn.pack(expand=True)# 4. 状态提示区域frame4=ttk.Frame(self.root,padding="20 10 20 20")frame4.pack(fill=tk.X,expand=False)self.status_label=ttk.Label(frame4,text="状态:未开始",foreground="gray")self.status_label.pack(anchor=tk.CENTER)defselect_source_folder(self):"""选择存放JPG/PNG图片的源文件夹"""folder_path=filedialog.askdirectory(title="选择存放JPG/PNG图片的文件夹")iffolder_path:self.source_folder.set(folder_path)self.status_label.config(text=f"状态:已选择源文件夹:{os.path.basename(folder_path)}",foreground="blue")defselect_output_txt(self):"""选择提取结果保存的TXT文件路径"""file_path=filedialog.asksaveasfilename(title="保存图片文件名的TXT文件",defaultextension=".txt",filetypes=[("文本文档","*.txt"),("所有文件","*.*")])iffile_path:self.output_txt.set(file_path)self.status_label.config(text=f"状态:已选择输出文件:{os.path.basename(file_path)}",foreground="blue")defextract_image_names(self):"""核心功能:提取JPG/PNG图片文件名并保存到TXT"""# 获取输入输出路径source_dir=self.source_folder.get().strip()output_path=self.output_txt.get().strip()# 路径有效性校验ifnotsource_dirornotos.path.isdir(source_dir):messagebox.showerror("错误","请先选择有效的图片文件夹!")returnifnotoutput_path:messagebox.showerror("错误","请先选择输出TXT文件的保存路径!")return# 筛选文件夹内所有JPG和PNG图片文件(忽略大小写)image_files=[]image_suffixes=(".jpg",".jpeg",".png")# 兼容jpeg格式,更全面forfilenameinos.listdir(source_dir):# 筛选图片后缀,忽略大小写iffilename.lower().endswith(image_suffixes):file_full_path=os.path.join(source_dir,filename)# 确保是文件(排除同名文件夹)ifos.path.isfile(file_full_path):image_files.append(filename)# 校验是否存在图片文件ifnotimage_files:messagebox.showwarning("警告","所选文件夹中未找到JPG/PNG格式的图片文件!")self.status_label.config(text="状态:未找到图片文件,提取失败",foreground="red")return# 按文件名排序,保证提取顺序稳定可追溯image_files.sort()try:# 以UTF-8编码写入TXT文件,兼容中文文件名withopen(output_path,"w",encoding="utf-8")astxt_file:# 遍历图片文件名,逐行写入(也可自定义格式)total_images=len(image_files)forindex,img_nameinenumerate(image_files,1):# 逐行写入图片文件名,可自定义格式(如添加序号)txt_file.write(f"{img_name}\n")# 更新实时提取进度self.status_label.config(text=f"状态:正在提取{index}/{total_images}个图片文件名...",foreground="orange")# 强制刷新界面,显示最新状态self.root.update_idletasks()# 提取完成提示messagebox.showinfo("成功",f"图片文件名提取完成!\n共提取{total_images}个图片文件\n输出TXT文件:{output_path}")self.status_label.config(text=f"状态:提取成功!共处理{total_images}个图片文件",foreground="green")exceptExceptionase:# 异常捕获与友好提示error_info=f"提取失败!错误信息:{str(e)}"messagebox.showerror("错误",error_info)self.status_label.config(text=f"状态:{error_info}",foreground="red")if__name__=="__main__":# 创建主窗口并运行程序root=tk.Tk()app=ImageNameExtractTool(root)root.mainloop()python语言JPGPNG图片文件名提取工具-输出TXT软件代码
张小明
前端开发工程师
解析 ‘GraphRAG’:如何结合 Neo4j 与 LangChain 利用关系路径增强 LLM 的全局摘要能力?
GraphRAG:结合 Neo4j 与 LangChain 提升 LLM 全局摘要能力的技术讲座各位同仁,大家好。今天我们齐聚一堂,探讨一个在当前信息爆炸时代极具价值的话题:如何利用图数据库的强大关系建模能力与大型语言模型(LLM࿰…
【毕业设计】基于springBoot的高校大学生党建系统设计与实现(源码+文档+远程调试,全bao定制等)
博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…
PyTorch-CUDA-v2.7镜像中批量处理Markdown转HTML静态页面
PyTorch-CUDA-v2.7镜像中批量处理Markdown转HTML静态页面 在AI项目开发过程中,工程师们常常面临一个看似简单却极易被忽视的问题:如何高效、一致地将大量技术文档从Markdown格式转换为可供展示的HTML静态页面?尤其是在团队协作、知识沉淀或对…
AI运维宝典:4大关键阶段全解析,附实操步骤与避坑指南,助力大模型成功应用
本文系统介绍AI项目全流程运维,分四大阶段(启动前、开发期、部署期、运营期)详解核心关注点、实操步骤和避坑指南,配真实案例。解析模型漂移、灰度发布等关键术语,通过前置规划、过程管控和持续优化,助力AI模型平稳落地并持续创造…
YOLOv5-Net 终极部署指南:5分钟快速上手目标检测
YOLOv5-Net 终极部署指南:5分钟快速上手目标检测 【免费下载链接】yolov5-net 项目地址: https://gitcode.com/gh_mirrors/yol/yolov5-net 🚀 环境搭建:零基础快速入门 必备工具清单 .NET SDK 版本检查与安装:确保安装了…
2025最新!专科生毕业论文必备8个AI论文平台测评与推荐
2025最新!专科生毕业论文必备8个AI论文平台测评与推荐 2025年专科生毕业论文必备AI平台测评与推荐 随着人工智能技术的不断进步,越来越多的专科生开始借助AI工具辅助完成毕业论文写作。然而,面对市场上琳琅满目的AI论文平台,如何选…