繁体   English   中英

如何使用 Python ElementTree 获取元素树的所有子元素?

[英]How to get all sub-elements of an element tree with Python ElementTree?

我想找到一种方法来获取元素树的所有子元素,就像ElementTree.getchildren()那样,因为getchildren()自 Python 2.7 版以来已被弃用。
我不想再使用它了,尽管我目前仍然可以使用它。

elem所有子元素(后代):

all_descendants = list(elem.iter())

一个更完整的例子:

>>> import xml.etree.ElementTree as ET
>>> a = ET.Element('a')
>>> b = ET.SubElement(a, 'b')
>>> c = ET.SubElement(a, 'c')
>>> d = ET.SubElement(a, 'd')
>>> e = ET.SubElement(b, 'e')
>>> f = ET.SubElement(d, 'f')
>>> g = ET.SubElement(d, 'g')
>>> [elem.tag for elem in a.iter()]
['a', 'b', 'e', 'c', 'd', 'f', 'g']

要排除根本身:

>>> [elem.tag for elem in a.iter() if elem is not a]
['b', 'e', 'c', 'd', 'f', 'g']

在 pydoc 中提到在节点上使用 list() 方法来获取子元素。
list(elem)

如果要获取所有元素“a”,可以使用:

a_lst = list(elem.iter('a'))

如果elem也是 'a',它将被包括在内。

也许这不符合 OP 的实际问题,但在更大的意义上,我建议如果有人想要使用某个名称命名的所有元素,例如“对象”可以使用(@Turtles Are Cute 的替代方法,至少对我来说看起来更自然):

objs = tree.findall('object')

它还返回一个列表。

现有的答案都不能找到所有的孩子。 此解决方案使用 BeautifulSoup 而不是 ETree,但会找到所有子级,而不仅仅是顶级:

from bs4 import BeautifulSoup    

with open(filename) as f:
    soup = BeautifulSoup(f, 'xml')

results = soup.find_all('element_name')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM