python 對(duì)xml解析的示例
一、我們對(duì)XML的讀取進(jìn)行一波演示
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文件定義為一個(gè)對(duì)象
#得到文檔對(duì)象
doc = DOMTree.documentElement#打印出了帶有根目錄的名字的對(duì)象
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é)點(diǎn)的屬性值

二、同時(shí)我們還可以使用xml.DOM.etree這種方式來進(jìn)行解析
我們提供方法:
(1)以樹形結(jié)構(gòu)來表示xml;
(2)root.getiterator:得到相應(yīng)的可迭代的node集合
(3)root.iter
(4)find(node_name):查找指定node_name的節(jié)點(diǎn),返回一個(gè)node
(5)root.findall(node_name):返回多個(gè)node_name的節(jié)點(diǎn)
(6)node.tag:node對(duì)應(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 如何對(duì)xml解析的詳細(xì)內(nèi)容,更多關(guān)于python 對(duì)xml解析的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Python如何使用ElementTree解析xml
- Python 解析xml文件的示例
- Python利用命名空間解析XML文檔
- python讀取xml文件方法解析
- Python 解析簡(jiǎn)單的XML數(shù)據(jù)
- Python如何對(duì)XML 解析
- python解析xml文件方式(解析、更新、寫入)
- python實(shí)現(xiàn)XML解析的方法解析
- Python大數(shù)據(jù)之使用lxml庫(kù)解析html網(wǎng)頁(yè)文件示例
- Python3使用xml.dom.minidom和xml.etree模塊兒解析xml文件封裝函數(shù)的方法
- python解析xml簡(jiǎn)單示例
相關(guān)文章
在Python的struct模塊中進(jìn)行數(shù)據(jù)格式轉(zhuǎn)換的方法
這篇文章主要介紹了在Python的struct模塊中進(jìn)行數(shù)據(jù)格式轉(zhuǎn)換的方法,文中還給出了C語(yǔ)言和Python語(yǔ)言的數(shù)據(jù)類型比較,需要的朋友可以參考下2015-06-06
python?基本結(jié)構(gòu)語(yǔ)句(函數(shù)和模塊)
這篇文章主要介紹了python?基本結(jié)構(gòu)語(yǔ)句(函數(shù)和模塊),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
OpenCV利用手勢(shì)識(shí)別實(shí)現(xiàn)虛擬拖放效果
這篇文章主要介紹了利用OpenCV實(shí)現(xiàn)手勢(shì)識(shí)別,從而進(jìn)行虛擬拖放效果,我們可以使用這個(gè)技術(shù)實(shí)現(xiàn)一些游戲,控制機(jī)械臂等很多有趣的事情。感興趣的可以學(xué)習(xí)一下2022-01-01
python使用openpyxl庫(kù)讀寫Excel表格的方法(增刪改查操作)
這篇文章主要介紹了python使用openpyxl庫(kù)讀寫Excel表格的方法(增刪改查操作),本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05
python實(shí)現(xiàn)隨機(jī)密碼字典生成器示例
這篇文章主要介紹了python實(shí)現(xiàn)隨機(jī)密碼字典生成器示例,需要的朋友可以參考下2014-04-04
python基礎(chǔ)之變量和數(shù)據(jù)類型
這篇文章主要介紹了python的變量和數(shù)據(jù)類型,實(shí)例分析了Python中返回一個(gè)返回值與多個(gè)返回值的方法,需要的朋友可以參考下2021-10-10
神經(jīng)網(wǎng)絡(luò)python源碼分享
這篇文章主要介紹了神經(jīng)網(wǎng)絡(luò)python源碼分享,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12

