使用 Python 从 XML 读取/提取数据



我正在尝试使用xml.etree.ElementTree使用Python从XML中读取/提取数据。 不幸的是,到目前为止,我还没有找到该怎么做。很可能是因为我不明白 xml 是如何工作的。

这个想法是将 DocumentId 编号写成一个列表

这是我的XML文件:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<RegisterSearch TotalResults="4">
<SearchResults>
<Document DocumentId="1348828088501913376">
<DocumentNumber>001</DocumentNumber>
</Document>
<Document DocumentId="1348828088501881434">
<DocumentNumber>001</DocumentNumber>
</Document>
<Document DocumentId="1348828088539553420">
<DocumentNumber>010</DocumentNumber>
</Document>
<Document DocumentId="1348828088539570694">
<DocumentNumber>010</DocumentNumber>
</Document>
</SearchResults>
</RegisterSearch>

这是我的Python代码:

#!/usr/bin/python2
import xml.etree.ElementTree as ET
tree = ET.parse('documents.xml')
root = tree.getroot()
for elem in root:
if(elem.tag=='Document'):
print elem.get('DocumentId')

这就是我试图实现的目标:

1348828088501913376
1348828088501881434
1348828088539553420
1348828088539570694

实际上,代码没有带回任何东西...

提前感谢您的建议。

遍历您感兴趣的标签:

for elem in root.iter(tag='Document'):
print(elem.get('DocumentId'))

您的原始解决方案将适用于

for elem in root.iter():
...

3.8版:https://docs.python.org/3/library/xml.etree.elementtree.html#finding-interesting-elements

v2.7: https://docs.python.org/2.7/library/xml.etree.elementtree.html#finding-interesting-elements