使用python(带有xmlns属性)解析XML不起作用

Ida*_*dan 1 python xml parsing xml-parsing

这是我第一次尝试用 python 解析 XML,所以答案可能很简单,但我无法弄清楚。

我正在使用 ElementTree 来解析一些 XML 文件。问题是,当具有此属性时,我无法在树内获得任何结果:

<package xmlns="http://apple.com/itunes/importer" version="software5.1">
Run Code Online (Sandbox Code Playgroud)

当删除这个属性时,一切都很好。需要明确的是,我的意思是将 XML 文件的第一行更改为:

<package>
Run Code Online (Sandbox Code Playgroud)

一切都很好。

我究竟做错了什么?

这是我的代码:

import xml.etree.ElementTree as ET

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

p = root.find(".//intervals/interval")

print p
for interval in root.iterfind(".//intervals/interval"):
    start_date = interval.find('start_date').text
    end_date = interval.find('end_date').text
    print start_date, end_date
Run Code Online (Sandbox Code Playgroud)

请帮忙。谢谢!

更新:XML 文件:

<?xml version="1.0" encoding="UTF-8"?>
<package xmlns="http://apple.com/itunes/importer" version="software5.1">
<metadata_token>TOKEN</metadata_token>
<provider>Provider Name</provider>
<team_id>Team_ID_Here</team_id>
<software>
    <!--Apple ID: 01234567-->
    <vendor_id>vendorSKU</vendor_id>
    <read_only_info>
        <read_only_value key="apple-id">01234567</read_only_value>
    </read_only_info>
    <software_metadata>
        <versions>
            <version string="1.0">
                <locales>
                    <locale name="en-US">
                        <title>title text</title>
                        <description>Description text</description>
                        <keywords>
                            <keyword>key1</keyword>
                            <keyword>key2</keyword>
                        </keywords>
                        <version_whats_new>New things here</version_whats_new>
                        <support_url>http://someurl.com</support_url>
                        <software_screenshots>
                            <software_screenshot display_target="iOS-3.5-in" position="1">

                            </software_screenshot>
                            <software_screenshot display_target="iOS-4-in" position="1">

                            </software_screenshot>
                        </software_screenshots>
                    </locale>
                </locales>
            </version>
        </versions>
        <products>
            <product>
                <territory>WW</territory>
                <cleared_for_sale>true</cleared_for_sale>
                <sales_start_date>2013-01-05</sales_start_date>
                <intervals>
                    <interval>
                        <start_date>2013-08-25</start_date>
                        <end_date>2014-09-01</end_date>
                        <wholesale_price_tier>5</wholesale_price_tier>
                    </interval>
                    <interval>
                        <start_date>2014-09-01</start_date>
                        <wholesale_price_tier>6</wholesale_price_tier>
                    </interval>
                </intervals>
                <allow_volume_discount>true</allow_volume_discount>
            </product>
        </products>
    </software_metadata>
</software>
Run Code Online (Sandbox Code Playgroud)

Rah*_*ani 5

这是因为,python 中的 xml 不能自动识别名称空间。我们需要为树中的每个元素添加命名空间前缀以进行查找。

    import xml.etree.ElementTree as ET

namespaces = {"pns" : "http://apple.com/itunes/importer"}
tree = ET.parse('metadataCopy.xml')
root = tree.getroot()

p = root.find(".//pns:intervals/pns:interval", namespaces=namespaces)

print p
for interval in root.iterfind(".//pns:intervals/pns:interval",namespaces=namespaces):
    start_date = interval.find('pns:start_date',namespaces=namespaces)
    end_date = interval.find('pns:end_date',namespaces=namespaces)
    st_text = end_text = None
    if start_date is not None:
        st_text = start_date.text
    if end_date is not None:
        end_text = end_date.text 
    print st_text, end_text
Run Code Online (Sandbox Code Playgroud)

共享的 xml 文件不是格式良好的 XML。最后一个标签必须以包标签结尾。完成此更改后,程序将产生:

<Element '{http://apple.com/itunes/importer}interval' at 0x178b350>
2013-08-25 2014-09-01
2014-09-01 None
Run Code Online (Sandbox Code Playgroud)

如果可以更改库,您可以寻找使用 lxml。lxml 对命名空间的使用提供了很好的支持。在这里查看快速简短教程http://lxml.de/tutorial.html#namespaces