python 对xml解析的示例
一、我们对XML的读取进行一波演示
importxml.dom.minidom
#负责解析xml文件的包
fromxml.dom.minidomimportparse
#使用minidom打开xml文件
DOMTree=xml.dom.minidom.parse("D30_1_XmlNameSpace.xml")
print(DOMTree)#将该XML文件定义为一个对象
#得到文档对象
doc=DOMTree.documentElement#打印出了带有根目录的名字的对象
print(doc)
#显示子元素
foreleindoc.childNodes:
ifele.nodeName=="student:Name":
print("=======Node:{0}=======".format(ele.nodeName))
print(doc.childNodes)
ifele.nodeName=="Age":
print(ele.getAttribute("jio"))#获取某一节点的属性值
二、同时我们还可以使用xml.DOM.etree这种方式来进行解析
我们提供方法:
(1)以树形结构来表示xml;
(2)root.getiterator:得到相应的可迭代的node集合
(3)root.iter
(4)find(node_name):查找指定node_name的节点,返回一个node
(5)root.findall(node_name):返回多个node_name的节点
(6)node.tag:node对应的tagename
(7)node.text:node的文本值
(8)node.attrib:是node的属性的字典类型的内容
mportxml.etree.ElementTree
root=xml.etree.ElementTree.parse("D30_1_XmlNameSpace.xml")
nodes=root.getiterator()
fornodeinnodes:
print("{0}---{1}".format(node.tag,node.text))
print("===========================================")
ele_room_name=root.find("Location")
print(type(ele_room_name))
print("{0}----{1}".format(ele_room_name.tag,ele_room_name.text))
print("===========================================")
ele_room_name2=root.findall("{http://my_room}Name")#这里如果使用“room:Name”是解析不出来的
print(ele_room_name2)
foreleinele_room_name2:
print("{0}----{1}".format(ele.tag,ele.text))
ele_room_name2=root.findall("room:Name")
print(ele_room_name2)
foreleinele_room_name2:
print("{0}----{1}".format(ele.tag,ele.text))
三、源码
D30_2_XmlAnalysis.py
https://github.com/ruigege66/Python_learning/blob/master/D30_2_XmlAnalysis.py
以上就是python如何对xml解析的详细内容,更多关于python对xml解析的资料请关注毛票票其它相关文章!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。