一、我們對XML的讀取進行一波演示
import xml.dom.minidom
#負責解析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é)點的屬性值
二、同時我們還可以使用xml.DOM.etree這種方式來進行解析
我們提供方法:
(1)以樹形結構來表示xml;
(2)root.getiterator:得到相應的可迭代的node集合
(3)root.iter
(4)find(node_name):查找指定node_name的節(jié)點,返回一個node
(5)root.findall(node_name):返回多個node_name的節(jié)點
(6)node.tag:node對應的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解析的詳細內(nèi)容,更多關于python 對xml解析的資料請關注腳本之家其它相關文章!
您可能感興趣的文章:- Python如何使用ElementTree解析xml
- Python 解析xml文件的示例
- Python利用命名空間解析XML文檔
- python讀取xml文件方法解析
- Python 解析簡單的XML數(shù)據(jù)
- Python如何對XML 解析
- python解析xml文件方式(解析、更新、寫入)
- python實現(xiàn)XML解析的方法解析
- Python大數(shù)據(jù)之使用lxml庫解析html網(wǎng)頁文件示例
- Python3使用xml.dom.minidom和xml.etree模塊兒解析xml文件封裝函數(shù)的方法
- python解析xml簡單示例