考虑这个简单的XML架构:
<products>
<category name="furniture">
<item name="chair">
<size>
<small>10</small>
...and many more
<large>20</large>
</size>
</item>
</category>
</products>
我希望使用XPATH列出<size>
的子元素而没有实际内容。
$xml=simple_load_file('file.xml');
foreach ($xml->xpath("products/category[@=name'furniture']/item[@name='chair]/size") as $size)
echo $size->????? . '<br>';
$size->children();
输出实际文本:
10
20
我正在寻找以下输出:
small
...rest of elements
large
答案 0 :(得分:0)
您的Xpath表达式中有一些错误。第一个=处于错误的位置,主席字符串缺少结束报价。添加/*
您可以直接选择大小的子节点。
/products/category[@name='furniture']/item[@name='chair']/size/*
使用DOMDocument的完整源代码:
$xml = <<<'XML'
<products>
<category name="furniture">
<item name="chair">
<size>
<small>10</small>
<large>20</large>
</size>
</item>
</category>
</products>
XML;
$dom = new DOMDocument();
$dom->loadXml($xml);
$xpath = new DOMXPath($dom);
$nodes = $xpath->evaluate("/products/category[@name='furniture']/item[@name='chair']/size/*");
foreach ($nodes as $node) {
echo $node->localName, "\n";
}