В последней версии ElementTree (v1.3 или более поздней версии), вы можете просто сделать
input_element.find('..')
рекурсивно. Однако ElementTree, поставляемый с Python, не обладает этой функциональностью, и я не вижу ничего в классе Element, который смотрит вверх.
Я считаю, что это означает, что вам нужно сделать это сложным путем: через исчерпывающий поиск дерева элементов.
def get_ancestors_recursively(e, b):
"Finds ancestors of b in the element tree e."
return _get_ancestors_recursively(e.getroot(), b, [])
def _get_ancestors_recursively(s, b, acc):
"Recursive variant. acc is the built-up list of ancestors so far."
if s == b:
return acc
else:
for child in s.getchildren():
newacc = acc[:]
newacc.append(s)
res = _get_ancestors_recursively(child, b, newacc)
if res is not None:
return res
return None
Это медленно из-за ДПП, и проворачивает много списков для сбора мусора, но если вы можете иметь дело с этим она должна быть тонкой.
Да: используйте lxml, а затем вы можете вызвать elem.getparent() рекурсивно для обхода дерева, или вы можете использовать elem.xpath ('ancestor :: *') и получить список узлов-предков напрямую. (xpath работает с любым узлом как узлом контекста, а не только с корнем документа). –