python xml基于子元素文本打印特定的子节点

时间:2017-11-15 10:29:40

标签: python xml xml-parsing elementtree

我有一个示例XML,如下所示:

<data xmlns:nc="urn:ietf:params:xml:ns:netconf:base:1.0" xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
    <sessions xmlns="com:infinera:common:session">
        <session>
            <MoId>admin_12</MoId>
            <AccountName>admin</AccountName>
            <ProtocolType>SSH</ProtocolType>
            <MgmtAppType>CLI</MgmtAppType>
            <AuthenticationType>LOCAL</AuthenticationType>
        </session>
        <session>
            <MoId>admin_13</MoId>
            <AccountName>admin</AccountName>
            <ProtocolType>TELNET</ProtocolType>
            <MgmtAppType>TL1</MgmtAppType>
            <AuthenticationType>LOCAL</AuthenticationType>
        <session>
    </sessions>
</data>

在这里,我想遍历子项以查找 MgmtAppType 的值是否 TL1 ,如果是,我想打印与之关联的所有元素,即MoID,AccountName ,ProtocolType,MgmtAppType,AuthenticationType。 我尝试使用下面的代码,但这只打印 MgmtAppType

的值
import xml.etree.ElementTree as ET
root = ET.parse('C:\\session.xml')
roots = root.getroot()
for sess in roots.iter():
    if (sess.tag == "{com:infinera:common:session}MgmtAppType") and (sess.text == "TL1"):
            for chd in sess.iter():
                    print chd.text

如何根据搜索打印特定子节点的所有元素?

1 个答案:

答案 0 :(得分:1)

搜索命名空间XML示例的更好方法是使用您自己的前缀创建一个字典,并在搜索功能中使用这些字典:

import xml.etree.ElementTree as ET

root = ET.parse('C:\\session.xml').getroot()
ns = {'common': 'com:infinera:common:session'}
for session in root.findall('common:sessions/common:session[common:MgmtAppType="TL1"]', ns):
    print([el.text for el in list(session)])

输出(作为连续元素值的列表):

['admin_13', 'admin', 'TELNET', 'TL1', 'LOCAL']

https://docs.python.org/3/library/xml.etree.elementtree.html#parsing-xml-with-namespaces