欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python 對xml解析的示例

 更新時間:2021年02月27日 10:05:42   作者:心悅君兮君不知-睿  
這篇文章主要介紹了python 如何對xml解析,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下

一、我們對XML的讀取進行一波演示

import xml.dom.minidom

#負責(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é)點的屬性值

二、同時我們還可以使用xml.DOM.etree這種方式來進行解析

我們提供方法:

(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解析的詳細內(nèi)容,更多關(guān)于python 對xml解析的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論