[英]XML extract with php foreach is not looping
我正在尝试进行此循环,但它仅返回第一个值。
XML
<catalog>
<dd>
<categoryassignment categoryid="3d-magic" productid="000000000000109330_PURPLE/ BLUE"/>
<categoryassignment categoryid="3d-magic" productid="000000000000109330_PURPLE/ BLUE/ ORANGE"/>
<categoryassignment categoryid="3d-magic" productid="000000000000109330_RED/ GREEN/ YELLOW"/>
<categoryassignment categoryid="3d-magic" productid="000000000000109335_BLUE/YELLOW"/>
<categoryassignment categoryid="3d-magic" productid="000000000000109335_PURPLE/ORANGE"/>
<categoryassignment categoryid="3d-magic" productid="000000000000115881_GREEN/PURPLE"/>
<categoryassignment categoryid="3d-magic" productid="000000000000115881_ORANGE/BLUE"/>
<categoryassignment categoryid="3d-magic" productid="000000000000115881_RED/YELLOW"/>
<categoryassignment categoryid="3d-magic" productid="000000000109329001"/>
<categoryassignment categoryid="3d-magic" productid="000000000109329002"/>
<categoryassignment categoryid="3d-magic" productid="000000000109335001"/>
<categoryassignment categoryid="3d-magic" productid="000000000111568001"/>
<categoryassignment categoryid="3d-magic" productid="000000000111568002"/>
</dd>
PHP
$xml=simplexml_load_file("store.xml") or die("Failed to create an object");
foreach($xml->children() as $books) {
echo $books->categoryassignment['categoryid'];echo $books->categoryassignment['productid'];echo "<br>";}
从此处的示例中: https : //www.w3schools.com/php/php_xml_simplexml_get.asp
您需要更改引用数据的方式。 如果您首先通过以下方法进行快速调试:
print_r($xml);
您将看到您有一个像这样的对象:
SimpleXMLElement Object
(
[dd] => SimpleXMLElement Object
(
[categoryassignment] => Array
(
[0] => SimpleXMLElement Object
(
[@attributes] => Array
(
[categoryid] => 3d-magic
[productid] => 000000000000109330_PURPLE/ BLUE
)
)
[1] => SimpleXMLElement Object
(
[@attributes] => Array
(
[categoryid] => 3d-magic
[productid] => 000000000000109330_PURPLE/ BLUE/ ORANGE
)
)
... etc ...
有了这些知识,您就可以轻松地了解将foreach
放在哪里。 就像这样(里面的$books
稍有变化):
foreach($xml->dd->categoryassignment as $books) {
echo $books['categoryid'];
echo ' ';
echo $books['productid'];
echo "<br>\n";
}
结果是:
3d-magic 000000000000109330_PURPLE/ BLUE 3d-magic 000000000000109330_PURPLE/ BLUE/ ORANGE 3d-magic 000000000000109330_RED/ GREEN/ YELLOW 3d-magic 000000000000109335_BLUE/YELLOW 3d-magic 000000000000109335_PURPLE/ORANGE 3d-magic 000000000000115881_GREEN/PURPLE 3d-magic 000000000000115881_ORANGE/BLUE 3d-magic 000000000000115881_RED/YELLOW 3d-magic 000000000109329001 3d-magic 000000000109329002 3d-magic 000000000109335001 3d-magic 000000000111568001 3d-magic 000000000111568002
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.