Python 解析Xml文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 解析Xml文件相关的知识,希望对你有一定的参考价值。

 

 

python引入minidom 解析xml文件,下面是具体实例

 

<?xml version="1.0" encoding="utf-8" ?>
<info>
        <base>
        <platform>Windows</platform>
            <browser>Firefox</browser>
            <url>http://www.baidu.com</url>
               <login username="admin" password="123456"/>
               <login username="guest" password="654321"/>
        </base>
        <test>
            <province>北京</province>
            <province>广州</province>
                <city>深圳</city>
                <city>珠海</city>
            <province>浙江</province>
                <city>杭州</city>
        </test>
</info>

 

 

from xml.dom import minidom

#打开xml
#parse()解析,打开xml文件
dom = minidom.parse(info.xml)

#得到文档元素对象
root = dom.documentElement

print(root.nodeName)
print(root.nodeValue)
print(root.nodeType)
print(root.ELEMENT_NODE)

#获取标签
#getElementsByTagName()可以获得指定标签名的一组标签。
browser = root.getElementsByTagName(browser)
print(browser[0].tagName)

login = root.getElementsByTagName(login)
print(login[0].tagName)
print(login[1].tagName)

province = root.getElementsByTagName(province)
print(province[0].tagName)

#获取标签的属性值
#getAttribute()方法用于获取元素的属性值 和webdriver 的 get_attribute()方法相似
username = login[0].getAttribute("username")
print(username)
password = login[0].getAttribute("password")
print(password)

#获取标签对之间的数据
#获取第一个province标签对的值
#firstChild 属性返回被选节点的第一个子节点。data 表示获取该节点的数据,与webdriver 中的text方法相似。
province1 = province[0].firstChild.data
print(province1)

 

以上是关于Python 解析Xml文件的主要内容,如果未能解决你的问题,请参考以下文章

从 XML 声明片段获取 XML 编码:部分内容解析不支持 XmlDeclaration

如何在 python 代码中解析多个 xml 文件?

从流输入中解析没有根元素的 XML 片段列表

python使用ElementTree解析XML文件

在Tomcat的安装目录下conf目录下的server.xml文件中增加一个xml代码片段,该代码片段中每个属性的含义与用途

DOM解析xml文件