我有一个xml,如:
<AvailableCatgs>
<AvailableCatg>
<CategoryCode>01</CategoryCode>
<Pr>1857.48</Pr>
</AvailableCatg>
<AvailableCatg>
<CategoryCode>13</CategoryCode>
<Pr>1900.40</Pr>
</AvailableCatg>
<AvailableCatg>
<CategoryCode>09</CategoryCode>
<Pr>22.3</Pr>
</AvailableCatg>
</AvailableCatgs>
我必须循环所有AviableCatgs
并获取CategoryCode
和Pr
的值。我所做的是:
$xpath = new DOMXPath($mainXml);
$path = "//AvailableCatg";
$res = $xpath -> query($path);
foreach ($res as $aviable) {
print_r($aviable->CategoryCode->nodeValue);
}
但它并没有给我打印任何东西...... 我能怎么做?谢谢!
答案 0 :(得分:2)
您可以使用相对XPath查询执行此操作,如下所示:
$doc = new DOMDocument;
$doc->loadXML( $xml); // Your XML from above
$xpath = new DOMXPath( $doc);
foreach( $xpath->query( "//AvailableCatg") as $el) {
$ccode = $xpath->query( 'CategoryCode', $el)->item(0); // Get CategoryCode
$pr = $xpath->query( 'Pr', $el)->item(0); // Get Pr
var_dump($ccode->nodeValue . ' ' . $pr->nodeValue);
}
这将打印:
string(10) "01 1857.48"
string(10) "13 1900.40"
string(7) "09 22.3"
答案 1 :(得分:1)
您可以使用SimpleXml轻松完成此操作:
<?php
$xml=<<<x
<AvailableCatgs>
<AvailableCatg>
<CategoryCode>01</CategoryCode>
<Pr>1857.48</Pr>
</AvailableCatg>
<AvailableCatg>
<CategoryCode>13</CategoryCode>
<Pr>1900.40</Pr>
</AvailableCatg>
<AvailableCatg>
<CategoryCode>09</CategoryCode>
<Pr>22.3</Pr>
</AvailableCatg>
</AvailableCatgs>
x;
$s= simplexml_load_string($xml);
$res=$s->xpath('//AvailableCatg');
foreach ($res as $aviable) {
echo $aviable->CategoryCode, " -- ", $aviable->Pr, "<br/>";
}
?>
答案 2 :(得分:0)
您可以使用:
(string) current($xml->xpath("//group[@ref='HS_TYP']"))