import xml.dom.minidom #負(fù)責(zé)解析xml文件的包 from xml.dom.minidom import parse #使用minidom打開xml文件 DOMTree = xml.dom.minidom.parse("D30_1_XmlNameSpace.xml") print(DOMTree)#將該XML文件定義為一個對象 #得到文檔對象 doc = DOMTree.documentElement#打印出了帶有根目錄的名字的對象 print(doc) #顯示子元素 for ele in doc.childNodes: if ele.nodeName == "student:Name": print("=======Node:{0}=======".format(ele.nodeName)) print(doc.childNodes) if ele.nodeName == "Age": print(ele.getAttribute("jio"))#獲取某一節(jié)點的屬性值
我們提供方法:
(1)以樹形結(jié)構(gòu)來表示xml;
(2)root.getiterator:得到相應(yīng)的可迭代的node集合
(3)root.iter
(4)find(node_name):查找指定node_name的節(jié)點,返回一個node
(5)root.findall(node_name):返回多個node_name的節(jié)點
(6)node.tag:node對應(yīng)的tagename
(7)node.text:node的文本值
(8)node.attrib:是node的屬性的字典類型的內(nèi)容
mport xml.etree.ElementTree root = xml.etree.ElementTree.parse("D30_1_XmlNameSpace.xml") nodes = root.getiterator() for node in nodes: 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) for ele in ele_room_name2: print("{0}----{1}".format(ele.tag,ele.text)) ele_room_name2 = root.findall("room:Name") print(ele_room_name2) for ele in ele_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解析的詳細(xì)內(nèi)容,更多關(guān)于python 對xml解析的資料請關(guān)注腳本之家其它相關(guān)文章!
標(biāo)簽:阜新 昭通 興安盟 淘寶好評回訪 隨州 信陽 合肥 濟(jì)源
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python 對xml解析的示例》,本文關(guān)鍵詞 python,對,xml,解析,的,示例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。