python 對xml解析的示例
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.ElementTreeroot = 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解析的詳細內(nèi)容,更多關(guān)于python 對xml解析的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Android實現(xiàn)圖片自動切換功能(實例代碼詳解)2. js實現(xiàn)幻燈片輪播圖3. IntelliJ IDEA設(shè)置條件斷點的方法步驟4. ThinkPHP5 通過ajax插入圖片并實時顯示(完整代碼)5. Ajax引擎 ajax請求步驟詳細代碼6. JavaScript Tab菜單實現(xiàn)過程解析7. 完美解決idea突然間很卡的問題8. jsp+mysql實現(xiàn)網(wǎng)頁的分頁查詢9. javascript設(shè)計模式 ? 建造者模式原理與應(yīng)用實例分析10. Python使用oslo.vmware管理ESXI虛擬機的示例參考
