簡體   English   中英

PHP XPath-如何從結果中獲取價值

[英]PHP XPath - how to get value from result

我有來自Ebay的Followng XML文件

<?xml version="1.0"?>
<GeteBayDetailsResponse xmlns="urn:ebay:apis:eBLBaseComponents">
    <Timestamp>2012-07-04T12:02:14.541Z</Timestamp>
    <Ack>Success</Ack>
    <Version>779</Version>
    <Build>E779_INTL_BUNDLED_14986004_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>
    <SiteDetails>
        <Site>UK</Site>
        <SiteID>3</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Germany</Site>
        <SiteID>77</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Australia</Site>
        <SiteID>15</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>France</Site>
        <SiteID>71</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>eBayMotors</Site>
        <SiteID>100</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Italy</Site>
        <SiteID>101</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Netherlands</Site>
        <SiteID>146</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Spain</Site>
        <SiteID>186</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>India</Site>
        <SiteID>203</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>HongKong</Site>
        <SiteID>201</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Singapore</Site>
        <SiteID>216</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Malaysia</Site>
        <SiteID>207</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Philippines</Site>
        <SiteID>211</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>CanadaFrench</Site>
        <SiteID>210</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Poland</Site>
        <SiteID>212</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Belgium_Dutch</Site>
        <SiteID>123</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Belgium_French</Site>
        <SiteID>23</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Austria</Site>
        <SiteID>16</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Switzerland</Site>
        <SiteID>193</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <SiteDetails>
        <Site>Ireland</Site>
        <SiteID>205</SiteID>
        <DetailVersion>1</DetailVersion>
        <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
    </SiteDetails>
    <UpdateTime>2009-07-09T10:48:17.000Z</UpdateTime>
</GeteBayDetailsResponse>

我需要獲取節點SiteID的值,其中節點Site與我傳遞的任何變量匹配。 我的代碼是:

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

$siteIDList =  $xpath->query("/GeteBayDetailsResponse/SiteDetails[Site=$site]/SiteID");

var_dump($siteIDList);
echo $siteIDList->SiteID;

我得到以下結果:

object(DOMNodeList)#11 (0) {
}

有人可以幫忙嗎? 我想得到3的值。

我認為您必須在$site周圍加上引號並添加名稱空間:

$xpath = new DOMXPath($xmlDoc);
$xpath->registerNamespace('ebay', 'urn:ebay:apis:eBLBaseComponents');

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

可以肯定的是,能否給我們提供給您此結果的$site值?

編輯:按照Vaman Kulkarni的建議添加了名稱空間。

編輯:從弗洛朗的答案使用的API registerNamespace

您的XML文件包含默認名稱空間。 因此,您可以像下面在代碼中那樣在默認名稱空間( urn:ebay:apis:eBLBaseComponents )中注冊像ebay這樣的變量名稱,並在xpath之后使用

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

$siteIDList = $xpath->query("//ebay:Site[text()='$site']/following-sibling::ebay:SiteID/text()");

要么

您可以使用以下XPATH,除了評估它之外,它不需要任何其他代碼:-)

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

注意: $ site是<Site>節點的運行時值,將匹配<SiteID>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM