欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

python 对xml解析的示例

程序员文章站 2022-04-26 13:58:05
一、我们对xml的读取进行一波演示import xml.dom.minidom#负责解析xml文件的包from xml.dom.minidom import parse​#使用minido...

一、我们对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"))#获取某一节点的属性值

python 对xml解析的示例

二、同时我们还可以使用xml.dom.etree这种方式来进行解析

我们提供方法:

(1)以树形结构来表示xml;

(2)root.getiterator:得到相应的可迭代的node集合

(3)root.iter

(4)find(node_name):查找指定node_name的节点,返回一个node

(5)root.findall(node_name):返回多个node_name的节点

(6)node.tag:node对应的tagename

(7)node.text:node的文本值

(8)node.attrib:是node的属性的字典类型的内容

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))

python 对xml解析的示例

三、源码

d30_2_xmlanalysis.py

https://github.com/ruigege66/python_learning/blob/master/d30_2_xmlanalysis.py

以上就是python 如何对xml解析的详细内容,更多关于python 对xml解析的资料请关注其它相关文章!

相关标签: python xml 解析