XML转CSV读取对应所有数据(tkinter工具)

简介: 代码段:处理xml标签和标签名的数据读取
#coding:utf-8importxml.dom.minidom,csvfromtkinterimport*deffc():
ifinput.get() ==""andinput2.get() ==""andlabel_input.get() ==""andkey_input.get() =="":
txt.insert(END, "请填写相关数据"+"\n")
elifinput.get() =="":
txt.insert(END, "xml文件名不能为空"+"\n")
elifinput2.get() =="":
txt.insert(END, "csv文件名不能为空"+"\n")
eliflabel_input.get() =="":
txt.insert(END, "标签名不能为空"+"\n")
elifkey_input.get() =="":
txt.insert(END, "字段名不能为空"+"\n")
else:
dom=xml.dom.minidom.parse(input.get()+".xml")
root=dom.documentElementlista= []
print(len(root.getElementsByTagName(label_input.get())))
foriinrange(len(root.getElementsByTagName(label_input.get()))):
test_case=root.getElementsByTagName(label_input.get())[i]
name_list=test_case.getAttribute(key_input.get())
txt.insert(END, name_list+"\n")
lista.append(test_case.getAttribute(key_input.get()))
print(name_list)
withopen(input2.get()+".csv", "a", newline='') asf:
writer=csv.writer(f)
writer.writerow(["读取到的值"])
row=listaforrinrow:
writer.writerow([r])
windos=Tk()
windos.geometry("600x500")#设置gui窗口大小windos.title("将xml文件中需要的数据读取到csv中")#gui窗口title名button=Button(windos,text="确定",command=fc)#按钮设置名字,按钮执行方法button.place(relx=0.85,rely=0.8,relwidth=0.1,relheight=0.1)
label=Label(windos,text="标签名")#gui页面title名称label.place(relx=-0.2,rely=0.01,relwidth=0.5,relheight=0.05)
label_input=Entry(windos)
label_input.place(relx=0.1,rely=0.01,relwidth=0.15,relheight=0.05)
key=Label(windos,text="字段名")#gui页面title名称key.place(relx=-0.2,rely=0.08,relwidth=0.5,relheight=0.05)
key_input=Entry(windos)
key_input.place(relx=0.1,rely=0.08,relwidth=0.15,relheight=0.05)
la=Label(windos,text="请输入xml文件名")#gui页面title名称la.place(relx=0.35,rely=0.05,relwidth=0.3,relheight=0.05)
input=Entry(windos)#输入框设置input.place(relx=0.35,rely=0.1,relwidth=0.3,relheight=0.05)
la2=Label(windos,text="请输入csv文件名")#gui页面title名称la2.place(relx=0.1,rely=0.15,relwidth=0.8,relheight=0.05)
input2=Entry(windos)#输入框设置input2.place(relx=0.35,rely=0.2,relwidth=0.3,relheight=0.05)
la3=Label(windos,text="读取到的数据")#gui页面title名称la3.place(relx=0.1,rely=0.25,relwidth=0.8,relheight=0.05)
txt=Text(windos)#gui输出页面txt.place(relx=0.25,rely=0.3,relwidth=0.5,relheight=0.5)
windos.mainloop()#启动#if __name__ == '__main__':#    fc()

XML文件:这里支持读取某个标签名和标签内容例如<testcase>中的name字段

<testcaseinternalid="73748"name="tci_setopt (9600 ,8 , ,1)"><node_order><![CDATA[1023]]></node_order><externalid><![CDATA[6751]]></externalid><version><![CDATA[1]]></version><execution_type><![CDATA[1]]></execution_type><importance><![CDATA[2]]></importance><estimated_exec_duration></estimated_exec_duration><status>1</status><is_open>1</is_open><active>1</active></testcase>

目录
相关文章
|
6月前
|
XML 前端开发 数据格式
请描述如何使用`BeautifulSoup`或其他类似的库来解析 HTML 或 XML 数据。
【2月更文挑战第22天】【2月更文挑战第67篇】请描述如何使用`BeautifulSoup`或其他类似的库来解析 HTML 或 XML 数据。
75 2
|
6月前
|
XML 存储 JSON
Python学习 -- 常用数据交换格式(CSV、XML、JSON)
Python学习 -- 常用数据交换格式(CSV、XML、JSON)
89 0
|
XML 存储 JSON
Python学习 -- 常用数据交换格式(CSV、XML、JSON)
Python学习 -- 常用数据交换格式(CSV、XML、JSON)
106 0
|
2月前
|
XML 存储 JSON
Twaver-HTML5基础学习(19)数据容器(2)_数据序列化_XML、Json
本文介绍了Twaver HTML5中的数据序列化,包括XML和JSON格式的序列化与反序列化方法。文章通过示例代码展示了如何将DataBox中的数据序列化为XML和JSON字符串,以及如何从这些字符串中反序列化数据,重建DataBox中的对象。此外,还提到了用户自定义属性的序列化注册方法。
47 1
|
3月前
|
XML 数据采集 存储
使用Java和XPath在XML文档中精准定位数据
在数据驱动的时代,从复杂结构中精确提取信息至关重要。XML被广泛用于数据存储与传输,而XPath则能高效地在这些文档中导航和提取数据。本文深入探讨如何使用Java和XPath精准定位XML文档中的数据,并通过小红书的实际案例进行分析。首先介绍了XML及其挑战,接着阐述了XPath的优势。然后,提出从大型XML文档中自动提取特定产品信息的需求,并通过代理IP技术、设置Cookie和User-Agent以及多线程技术来解决实际网络环境下的数据抓取问题。最后,提供了一个Java示例代码,演示如何集成这些技术以高效地从XML源中抓取数据。
142 7
使用Java和XPath在XML文档中精准定位数据
|
6月前
|
XML 前端开发 数据格式
BeautifulSoup 是一个 Python 库,用于从 HTML 和 XML 文件中提取数据
【5月更文挑战第10天】BeautifulSoup 是 Python 的一个库,用于解析 HTML 和 XML 文件,即使在格式不规范的情况下也能有效工作。通过创建 BeautifulSoup 对象并使用方法如 find_all 和 get,可以方便地提取和查找文档中的信息。以下是一段示例代码,展示如何安装库、解析 HTML 数据以及打印段落、链接和特定类名的元素。BeautifulSoup 还支持更复杂的查询和文档修改功能。
112 1
|
1月前
|
XML Web App开发 数据格式
HTML 页面显示 XML 数据
10月更文挑战第2天
|
1月前
|
XML JSON 前端开发
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
C#使用HttpClient四种请求数据格式:json、表单数据、文件上传、xml格式
386 0
|
3月前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
92 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
6月前
|
XML 机器学习/深度学习 JSON
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。
77 0
在火狐浏览器调ajax获取json数据时,控制台提示“XML 解析错误:格式不佳”。