PHP SimpleXML使用命名空间解析XML

时间:2013-06-17 14:08:18

标签: xml xpath xml-parsing simplexml xml-namespaces

我有这样的XML

<atom:feed xmlns="http://kosapi.feld.cvut.cz/schema/3" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:osearch="http://a9.com/-/spec/opensearch/1.1/" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xml:base="https://kosapi.fit.cvut.cz/api/3/" xml:lang="cs">
    <atom:entry>
        <atom:id>urn:cvut:kos:parallel:353810000</atom:id>
        <atom:updated>2013-06-02T14:15:54.0</atom:updated>
        <atom:author>
            <atom:name>kalvotom</atom:name>
        </atom:author>
        <atom:link rel="self" href="parallels/353810000/"/>
        <atom:content atom:type="xml" xsi:type="parallel">
            <capacity>24</capacity>
            <capacityOverfill>DENIED</capacityOverfill>
            <code>101</code>
            <course xlink:href="courses/BI-EFA/">Efektivní algoritmy</course>
            <enrollment>DENIED</enrollment>
            <occupied>0</occupied>
            <parallelType>TUTORIAL</parallelType>
            <semester xlink:href="semesters/B131/">Zimní 2013/2014</semester>
            <timetableSlot>
                <day>2</day>
                <duration>2</duration>
                <firstHour>1</firstHour>
                <parity>BOTH</parity>
                <room xlink:href="rooms/T9:346/">T9:346</room>
            </timetableSlot>
        </atom:content>
    </atom:entry>
</atom:feed>

我正在编写一个PHP脚本,需要为每个<capacity>提取<occupied><enrollment><atom:entry>个标记的内容(实际上有多个<atom:entry> }标签)。现在,我查找了一些关于如何处理命名空间的提示,但仍然无法使其工作。我的代码

$xml = simplexml_load_file("someurl");
$xml->registerXPathNamespace('prefix', 'http://www.w3.org/2005/Atom');
foreach($xml->xpath("//prefix:entry") as $entry) {
    $entry->registerXPathNamespace('prefix', 'http://www.w3.org/2005/Atom');
    $content = $entry->xpath("//prefix:content");
    echo $content->enrollment . " | " . $content->occupied . "/" . $content->capacity . "<br />\n";
}

我得到了

  

注意:尝试获取非对象的属性

1 个答案:

答案 0 :(得分:0)

xpath()的返回值是一个数组,即使它只有一个条目。也不要使用//作为第二个xpath调用的前缀。这将返回整个文档中的所有内容条目。

因此请尝试:

foreach($xml->xpath("//prefix:entry") as $entry) {
    $entry->registerXPathNamespace('prefix', 'http://www.w3.org/2005/Atom');
    $content = $entry->xpath("prefix:content");
    foreach($content as $c) { 
        echo $c->enrollment . " | " . $c->occupied . "/" . $c->capacity . "<br />\n";
    }
}

另请查看DOMXPath::query