使用php在嵌套xml中获取具有特定属性的多个值

时间:2015-11-18 22:05:10

标签: php xml nested-loops

我觉得这应该很容易,但是为了爱它我无法做到。我已经阅读并测试了几个小时,尝试了我在interwebs上找到的不同方法,包括simpleXML和PHP XML DOM,但它们都没有按照我需要的方式工作。

在调整并结合几个答案之后,我有点接近(我甚至找不到返回的方式,因为我已经在这里经历了这么多人),但并不完全正确。

我的代码:

$xml = simplexml_load_file(all_objects.xml");

$image = $xml->xpath('/objects/object/images/image');
foreach($image as $node) {
    $id = (string) $node->field[0];
    $url = (string) $node->field[4];
    echo $id . " : " . $url . "<br>";
}

但是我没有使用它们出现的键/数字[4],而是希望使用字段名称属性,例如&#34; ID&#34;和&#34; image_url&#34;,因为它们并不总是按此顺序排列。

这样的事情:

$id = (string) $node->field["id"];

但它不起作用,我尝试使用 field-&gt; attribtues() - &gt; id ,但没有运气。

xml:

<objects>
    <object>
        <field name="id">1055</field>
        <field name="title">example object</field>
        <images>
            <image number="1">
                <field name="id">55</field>
                <field name="version">1</field>
                <field name="image_url_small">http://example.com/image-small.jpg</field>
                <field name="image_url_medium">http://example.com/image-medium.jpg</field>
                <field name="image_url_big">http://example.com/image-big.jpg</field>
                <field name="image_url_original">http://example.com/image.jpg</field>
            </image>
            <image number="2">
                <field name="id">56</field>
                <field name="version">2</field>
                <field name="image_url">http://example.com/image2.jpg</field>
            </image>
            <image number="3">...</image>
            ...
            <image number="25">...</image>
        </images>
    </object>
    <object>...</object>
    <object>...</object>
</objects>

我真的很感激任何帮助/指导!我对此失去了理智。

1 个答案:

答案 0 :(得分:1)

您可以使用XPath获取具有特定属性值的子元素:

foreach($image as $node) {
    $id = (string) $node->xpath('field[@name="id"]')[0];
    $url = (string) $node->xpath('field[@name="image_url_big"]')[0];
    echo $id . " : " . $url . "<br>";
}

<强> eval.in demo

输出

55 : http://example.com/image-big.jpg
56 :
:
: