我有一个类似的XML代码:
<?xml version='1.0' encoding="UTF-8"?>
<coureurs>
<coureur>
<nom>Patrick</nom><hair>Inexistants</hair>
</coureur>
</coureurs>
我想打印:
Patrick inexistents
Etc...
For now my code is :
from lxml import etree
tree = etree.parse(file.xml)
for coureur in tree.xpath("/coureurs/coureur/nom"):
print(user.text)
但是,当我这样做时,它返回空白:对于tree.xpath(“ / coureurs / coureur / hair”)中的用户:它仅返回头发。我应该怎么办?
我仍然无法通过您提供的xml和代码重现该问题。但是似乎您已经遗漏了很多xml,并且XPATH
如果coureurs
不是xml(或其直接子级)的直接根目录,则很可能对您不起作用。
在这种情况下,您可以使用以下XPATH获取coureur
xml中的每个节点(即coureurs
节点的子节点)-
//coureurs/coureur
这将为您提供<coureur>
xml中的所有标记元素,然后对其进行迭代以打印其子文本。示例代码-
for user in tree.xpath('//coureurs/coureur'):
for child in user:
print(child.text,end=" ")
print()
示例/演示-
In [26]: s = """<?xml version='1.0' encoding="UTF-8"?>
....: <coureurs>
....: <coureur>
....: <nom>Patrick</nom><hair>Inexistants</hair>
....: </coureur>
....: </coureurs>"""
In [28]: tree = etree.fromstring(s.encode())
In [35]: for user in tree.xpath('//coureurs/coureur'):
....: for child in user:
....: print(child.text,end=" ")
....: print()
....:
Patrick Inexistants
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句