news 2026/5/27 15:36:38

python语言批量XML文件合并工具-标题+内容到TXT软件代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python语言批量XML文件合并工具-标题+内容到TXT软件代码
importtkinterastkfromtkinterimportttk,filedialog,messageboximportosclassXml2TxtMergeTool:def__init__(self,root):# 初始化主窗口self.root=root self.root.title("批量XML文件合并工具(标题+内容→TXT)")self.root.geometry("600x400")# 合理设置窗口大小,操作更舒适# 定义变量存储源文件夹路径和输出TXT文件路径self.source_folder=tk.StringVar()self.output_txt=tk.StringVar()# 创建界面所有控件self.create_widgets()defcreate_widgets(self):# 1. 源文件夹选择区域(存放所有XML文件的文件夹)frame1=ttk.Frame(self.root,padding="20 10 20 10")frame1.pack(fill=tk.X,expand=False)ttk.Label(frame1,text="待合并XML文件夹:").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.merge_btn=ttk.Button(frame3,text="开始合并XML(标题+内容)",command=self.merge_xml_to_txt,style="Accent.TButton")self.merge_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):"""弹窗选择存放XML文件的源文件夹"""folder_path=filedialog.askdirectory(title="选择存放所有XML文件的文件夹")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")defmerge_xml_to_txt(self):"""核心功能:批量合并XML文件(先标题<文件名>,后对应内容,输出到TXT)"""# 获取输入输出路径并去除首尾空格source_dir=self.source_folder.get().strip()output_path=self.output_txt.get().strip()# 第一步:校验路径有效性ifnotsource_dirornotos.path.isdir(source_dir):messagebox.showerror("错误","请先选择有效的XML文件文件夹!")returnifnotoutput_path:messagebox.showerror("错误","请先选择输出TXT文件的保存路径!")return# 第二步:筛选文件夹内所有XML文件(忽略大小写,兼容.XML/.Xml等格式)xml_files=[]forfilenameinos.listdir(source_dir):# 筛选.xml后缀文件,忽略大小写iffilename.lower().endswith(".xml"):file_full_path=os.path.join(source_dir,filename)# 确保是文件(排除同名文件夹,避免误处理)ifos.path.isfile(file_full_path):xml_files.append((filename,file_full_path))# 存储(文件名,完整路径)# 校验是否存在XML文件ifnotxml_files:messagebox.showwarning("警告","所选文件夹中未找到任何XML文件!")self.status_label.config(text="状态:未找到XML文件,合并失败",foreground="red")return# 按文件名排序,保证合并顺序稳定可追溯xml_files.sort(key=lambdax:x[0])try:# 第三步:以UTF-8编码写入TXT文件(兼容中文文件名和XML内容)withopen(output_path,"w",encoding="utf-8")astxt_file:total_xml=len(xml_files)# 遍历每个XML文件,先写标题(文件名),再写内容forindex,(xml_filename,xml_file_path)inenumerate(xml_files,1):# 1. 写入XML文件标题(文件名,添加分隔线更易区分不同文件)txt_file.write(f"========== 【{xml_filename}】 ==========\n")# 2. 读取XML文件内容并写入TXTwithopen(xml_file_path,"r",encoding="utf-8",errors="ignore")asxml_file:xml_content=xml_file.read()txt_file.write(xml_content)# 每个XML文件内容后添加空行,分隔不同文件,提升可读性txt_file.write("\n\n")# 更新实时合并进度self.status_label.config(text=f"状态:正在合并{index}/{total_xml}个XML文件...",foreground="orange")# 强制刷新界面,确保进度实时显示self.root.update_idletasks()# 合并完成提示messagebox.showinfo("成功",f"XML文件合并完成!\n共合并{total_xml}个XML文件\n输出TXT文件:{output_path}")self.status_label.config(text=f"状态:合并成功!共处理{total_xml}个XML文件",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__":# 启动GUI程序root=tk.Tk()app=Xml2TxtMergeTool(root)root.mainloop()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/27 2:31:57

PyTorch-CUDA-v2.7镜像中批量处理Markdown转HTML静态页面

PyTorch-CUDA-v2.7镜像中批量处理Markdown转HTML静态页面 在AI项目开发过程中&#xff0c;工程师们常常面临一个看似简单却极易被忽视的问题&#xff1a;如何高效、一致地将大量技术文档从Markdown格式转换为可供展示的HTML静态页面&#xff1f;尤其是在团队协作、知识沉淀或对…

作者头像 李华
网站建设 2026/5/22 9:59:49

YOLOv5-Net 终极部署指南:5分钟快速上手目标检测

YOLOv5-Net 终极部署指南&#xff1a;5分钟快速上手目标检测 【免费下载链接】yolov5-net 项目地址: https://gitcode.com/gh_mirrors/yol/yolov5-net &#x1f680; 环境搭建&#xff1a;零基础快速入门 必备工具清单 .NET SDK 版本检查与安装&#xff1a;确保安装了…

作者头像 李华
网站建设 2026/5/20 16:10:47

2025最新!专科生毕业论文必备8个AI论文平台测评与推荐

2025最新&#xff01;专科生毕业论文必备8个AI论文平台测评与推荐 2025年专科生毕业论文必备AI平台测评与推荐 随着人工智能技术的不断进步&#xff0c;越来越多的专科生开始借助AI工具辅助完成毕业论文写作。然而&#xff0c;面对市场上琳琅满目的AI论文平台&#xff0c;如何选…

作者头像 李华