0

这里有点初学者问题:

假设我有一个 xml 块:

<root>
 <district>
  <house><room><door/><room></house>
 </district>
 <district>
  <street>
   <house>and so on</house>
  </street>

等等

使用 ElementTree 我可以:

houses=doc.findall(".//house")

选择所有的房子节点,不管它们的父节点。我现在要做的是将每个房屋节点变成一个单独的树对象。

这样做的部分原因是我想再做一次发现:

door=houseXml.findall(".//door")

我可以做类似的事情:

for _house in houses:
    houseXml=_house.getiterator

但这似乎不符合我的要求。

我哪里错了?

4

1 回答 1

2

您可以调用findall第一个返回的元素findall

>>> doc = """<root>
...  <district>
...   <house><room><door/></room></house>
...  </district>
...  <district>
...   <street>
...    <house>and so on</house>
...   </street>
...  </district>
... </root>"""
>>>
>>> from xml.etree import cElementTree as ET
>>>
>>> r = ET.XML(doc)
>>>
>>> for house in r.findall('.//house'):
...   print house, house.findall('.//door')
...
<Element 'house' at 0xb7f3ea70> [<Element 'door' at 0xb7f3eab8>]
<Element 'house' at 0xb7f3eb00> []
>>>
于 2010-03-25T12:57:14.303 回答