我想找到一种方法来获取元素树的所有子元素,因为自 Python 2.7 版ElementTree.getchildren()
以来已弃用。
我不想再使用它了,虽然我现在仍然可以使用它。getchildren()
问问题
99135 次
5 回答
22
的所有子元素(后代)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']
于 2012-05-02T06:56:49.120 回答
10
在 pydoc 中提到在节点上使用 list() 方法来获取子元素。
list(elem)
于 2018-08-22T08:47:06.140 回答
6
如果要获取所有元素“a”,可以使用:
a_lst = list(elem.iter('a'))
如果elem
也是'a',它将被包括在内。
于 2012-05-02T11:31:21.737 回答
3
也许这与 OP 实际问题不对应,但在更大的意义上,我建议如果有人想获得所有以某个名称命名的元素,例如“对象”可以使用(@Turtles Are Cute的另一种方法至少对我来说看起来更自然):
objs = tree.findall('object')
它还返回一个列表。
于 2018-08-24T09:27:54.537 回答
2
没有一个现有的答案会找到所有的孩子。此解决方案使用 BeautifulSoup 而不是 ETree,但会找到所有子级,而不仅仅是顶级:
from bs4 import BeautifulSoup
with open(filename) as f:
soup = BeautifulSoup(f, 'xml')
results = soup.find_all('element_name')
于 2017-03-02T10:13:25.407 回答