0

在过去的几个小时里,我一直被这个问题困扰。

这就是 XML 的样子

    <xmlblock>
        <data1>
              <username>someusername</username>
              <id>12345</id>
        </data1>
        <data2>
             <username>username</username>
             <id>11111</id>
        </data1>
    </xmlblock>

问题是这样的:

当它与给定的 id 匹配时,我需要用户名。

我不确定如何使用 iterfind 或 python 中的任何其他 lxml 模块进行双重搜索。

任何帮助将不胜感激。谢谢!

4

3 回答 3

2

一个(可能不是最好的)解决方案

>>> id_to_match = 12345
>>> for event, element in cElementTree.iterparse('xmlfile.xml'):
...     if 'data' in element.tag:
...        for data in element:
...            if data.tag == 'username':
...                username = data.text
...            if data.tag == 'id':
...                if data.text == id_to_match:
...                    print username
someusername                 
于 2012-04-27T14:39:42.280 回答
0

这是一个使用lxmlxpath的示例


>>> xml = '''
    <xmlblock>
        <data1>
              <username>someusername</username>
              <id>12345</id>
        </data1>
        <data2>
             <username>username</username>
             <id>11111</id>
        </data2>
    </xmlblock>'''
>>> doc = lxml.etree.fromstring(xml)
>>> matching_nodes = doc.xpath('//id[text()="11111"]/../username')
>>> for node in matching_nodes:
        print node.text
username
于 2012-04-27T16:18:47.227 回答
0

如果您可以使用minidom,则以下内容应该可以使用

from xml.dom import minidom
doc = minidom.parseString('<xmlblock><data1><username>someusername</username><id>12345</id></data1><data2><username>username</username><id>11111</id></data2></xmlblock>')
username = [elem.parentNode.getElementsByTagName('username') for elem in doc.getElementsByTagName('id') if elem.firstChild.data == '12345'][0][0].firstChild.data
print username
于 2012-04-27T15:27:48.903 回答