PHP - 获取XML节点的值。

3

我有一个如下的XML文件:

<?xml version="1.0" encoding="UTF-8"?>
<GeteBayDetailsResponse xmlns="urn:ebay:apis:eBLBaseComponents">
  <Timestamp>2012-07-04T13:54:51.873Z</Timestamp>
  <Ack>Success</Ack>
  <Version>779</Version>
  <Build>E779_CORE_BUNDLED_14986049_R1</Build>
  <SiteDetails>
    <Site>US</Site>
    <SiteID>0</SiteID>
    <DetailVersion>1</DetailVersion>
    <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
  </SiteDetails>
  <SiteDetails>
    <Site>Canada</Site>
    <SiteID>2</SiteID>
    <DetailVersion>1</DetailVersion>
    <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
  </SiteDetails>
</GeteBayDetailsResponse>

我正在尝试找到一种方法,在Site节点等于任何值的情况下获取SiteID节点的值。

我已经尝试使用XPath和DomDocument函数,但是没有成功。以下是一些混乱的代码:

    $xml_file ='SiteDetails.xml';
    $xmlDoc = new DomDocument();
    $xmlDoc->load($xml_file);
    $xpath = new DOMXpath($xmlDoc);

    $xpath->registerNamespace('ebay', 'urn:ebay:apis:eBLBaseComponents');

    //$siteIDList = $xpath->query("/ebay:GeteBayDetailsResponse/ebay:SiteDetails[ebay:Site='UK']/ebay:SiteID");
    //$siteIDList =  $xpath->query("/GeteBayDetailsResponse/SiteDetails[Site=\"UK\"]/SiteID");

//$siteIDList =  $xpath->query("//*[namespace-uri()='urn:ebay:apis:eBLBaseComponents' and name()='Site' and text()='$site']/following-sibling::*[namespace-uri()='urn:ebay:apis:eBLBaseComponents' and name()='SiteID']/text()");

    //var_dump($siteIDList);
    //echo $siteIDList->item(0)->nodeValue;

            /*$SiteDetails = $xmlDoc->getElementsByTagName('SiteDetails');
            $count = 0;
            foreach($SiteDetails as $details){
            //  print_r($details);
            echo $details->nodeValue;
                if ($details->nodeValue == $site){
                    echo 'YEAH';
                    echo $details->SiteID;
                }
            $count ++;  
            }*/
            //$siteID = $siteIDNode->item(8)->nodeValue;        

    //var_dump($siteIDNode);
}

有人能帮忙吗?如上所述,我很困惑...


你能说明一下吗:你想从Site节点等于X的特定SiteDetails节点中获取SiteID吗?例如,给定“Canada”,你想获得“2”吗? - Dmitry Kudryavtsev
是的,那就是确切的内容。谢谢。 - LeeTee
1个回答

3
一般的想法是遍历每个SiteDetails节点,并检查Site节点的值是否与您要查找的值匹配。
假设$xml包含您的xml作为SimpleXML实例。
$site = 'Canada';
$siteId = null;

foreach($xml->SiteDetails as $sd) {
  if(((string)$sd->Site) === $site) {
    $siteId = (int)$sd->SiteID;
    //break;
  }
}

var_dump($siteId); //int(2)

这里是在codepad上的工作示例

使用xpath()的解决方案

以下是使用xpath()的解决方案

$xml->registerXPathNamespace('ebay','urn:ebay:apis:eBLBaseComponents');
$site = 'Canada';
$siteId = $xml->xpath('ebay:SiteDetails/ebay:Site[text()="'.$site.'"]/../ebay:SiteID');
echo (string)$siteId[0]; //2

在CodePad上的工作示例

解释:

  1. 首先,我们使用xpath的text()函数查找具有值为“Canada”(或$site中的任何其他值)的子节点SiteSiteDetails节点。
  2. 然后,我们使用.. xpath选择器转到相应的父级SiteDetails
  3. 最后,我们从所需的SiteDetails元素中提取SiteID的值。

祝你好运 =)


我尝试使用XPath选择第二个选项,但是出现了“无法将类型为DOMNodeList的对象用作数组”的错误。当我执行var_dump时,我得到一个空对象。这与我之前的代码得到的结果相同。我将尝试第一个选项。 - LeeTee
@LeeTee 试着使用SimpleXML代替DOMNodeList,这应该可以解决问题。 - Dmitry Kudryavtsev

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接