西宁市网站建设_网站建设公司_JavaScript_seo优化
2025/12/29 20:46:27 网站建设 项目流程
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()

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询