无法获得预期的XML输出

时间:2019-02-16 23:10:30

标签: python xml python-3.x elementtree

我有Python3,并且正在关注此XML教程https://docs.python.org/3.7/library/xml.etree.elementtree.html

我希望输出所有DailyIndexRatio的列表

DailyIndexRatio {'CUSIP': '912810FD5','IssueDate': '1998-04-15', 
'Date':'2019-03-01','RefCPI':'251.23300','IndexRatio':'1.55331' }
 ....

代替我的代码输出

DailyIndexRatio {}
 ....

如何解决?

这是代码

import xml.etree.ElementTree as ET

tree = ET.parse('CPI_20190213.xml')
root = tree.getroot()

print(root.tag)
print(root.attrib)

for child in root:
    print(child.tag,child.attrib)

然后我从https://treasurydirect.gov/xml/CPI_20190213.xml下载了xml文件

2 个答案:

答案 0 :(得分:0)

您正在打印属性,但是该元素没有任何属性。

这是一个具有属性的元素:

<element name="Bob" age="40" sex="male" />

但是您要打印的元素没有这些元素。它具有子元素

<element>
    <name>Bob</name>
    <age>40</age>
    <sex>male</sex>
</element>

答案 1 :(得分:0)

import xml.etree.ElementTree as ET

tree = ET.parse('CPI_20190213.xml') # Load the XML
root = tree.getroot() # Get XML root element
e = root.findall('.//DailyIndexRatio') # use xpath to find relevant elements
# for each element
for i in e:
    # create a dictionary object.
    d = {}
    # for each child of element
    for child in i:
        # add the tag name and text value to the dictionary
        d[child.tag] = child.text
    # print the DailyIndexRatio tag name and dictionary
    print (i.tag, d)

输出:

DailyIndexRatio {'CUSIP': '912810FD5', 'IssueDate': '1998-04-15', 'Date': '2019-03-01', 'RefCPI': '251.23300', 'IndexRatio': '1.55331'}
DailyIndexRatio {'CUSIP': '912810FD5', 'IssueDate': '1998-04-15', 'Date': '2019-03-02', 'RefCPI': '251.24845', 'IndexRatio': '1.55341'}
DailyIndexRatio {'CUSIP': '912810FD5', 'IssueDate': '1998-04-15', 'Date': '2019-03-03', 'RefCPI': '251.26390', 'IndexRatio': '1.55351'}
DailyIndexRatio {'CUSIP': '912810FD5', 'IssueDate': '1998-04-15', 'Date': '2019-03-04', 'RefCPI': '251.27935', 'IndexRatio': '1.55360'}
...