XMl在php中解析查询

时间:2014-05-09 21:08:20

标签: php xml parsing domdocument

我正在解析xml节点,我做错了什么,但我不知道是什么。 我有这个xml:

$xml="    <root>
        <info>
        <company/>
        <user_id>43</user_id>
        <currency>EUR</currency>
        </info>
        <products>
         <product>
          <id>1336</id>
          <pn>NX.RZNAA.003</pn>
          <stock>1.00</stock>
         </product>
         <product>
          <id>1337</id>
          <pn>NX.RZNAA.004</pn>
          <stock>4.00</stock>
          <item_number>5</item_number>
         </product>
        </products>
     </root>";

正如你所看到的,我有两个&#34;产品&#34;具有子节点的节点。但在第一节点&#34;产品&#34;我有一个节点少于秒。在第二个节点&#34; item_number&#34;添加(它是可选节点,如果它有值,则它在xml中,否则不是)。当我解析这个节点时,我的解析器从第二个节点返回值&#34; product&#34;即使我在第一个节点上。

有人知道这里有什么问题吗?

这是我的代码:

$xmlDoc = new DOMDocument();
$xmlDoc->load($xml) ; 
$xpath = new DOMXPath($xmlDoc);
$tagForCount="count(//".$arrayPolja[0].")"; 
$x=$xmlDoc->getElementsByTagName("product");
$xpath = new DomXpath($xmlDoc);
$count = 3;
$arrayPolja[0] = "id";
$arrayPolja[1] = "pn";
$arrayPolja[2] = "stock";
$arrayPolja[3] = "item_number";
$r=0;
foreach ($x as $product) {
     $i=0;
     while ($i<=$count)
     {
        $polje=$arrayPolja[$i];
        $values[$i]=$xpath->query($polje, $product)->item($r)->textContent;     
        $i++;
     }
    $r++;
}

1 个答案:

答案 0 :(得分:1)

首先,循环中的第二次迭代将覆盖数组的值&#34; $ values&#34;这就是为什么你只能看到第二个产品节点的值(如果你正在检查&#34; $ values&#34;数组,这就是我假设你正在做的事情)。

试试这个:

$xmlDoc = new DOMDocument();
$xmlDoc->load($xml); 
$xpath = new DOMXPath($xmlDoc);
$x = $xmlDoc->getElementsByTagName("product");
$array = array('id','pn','stock','item_number');
$values = array();

foreach ($x as $product) {
    $data = array();

    // node name here
    $data['node'] = $product->nodeName;

    foreach ($array as $v){
        $obj = $xpath->query($v, $product)->item(0);
        if (gettype($obj) == 'object'){
            $data[$v] = $obj->textContent; 
        }  
    }
    $values[] = $data;
}
echo '<pre>' . print_r($values, true). '</pre>';

这应该产生这个:

Array
(
[0] => Array
    (
        [node] => product
        [id] => 1336
        [pn] => NX.RZNAA.003
        [stock] => 1.00
    )

[1] => Array
    (
        [node] => product
        [id] => 1337
        [pn] => NX.RZNAA.004
        [stock] => 4.00
        [item_number] => 5
    )