2

yqlによって生成されたxmlからスパンからID「yfs_a00_xauusd=x」のデータを取得しようとしています。

私はこれを試しました..しかし結果は

質問:true http://finance.yahoo.com/q?s=XAGUSD%3DX&ql=1 613 6002742628.3600ここで私は28.3600だけを取得したい

<?php
session_start();
$yql_base_url = "http://query.yahooapis.com/v1/public/yql";  
$xpath='//*[@id="yfs_g00_xagusd=x"]';
$url = 'http://finance.yahoo.com/q?s=XAGUSD%3DX&ql=1';
$yql_query = "select * from html where url=$url and xpath = $xpath;";  
$yql_query_url = $yql_base_url . "?q=" . urlencode($yql_query);
$yql_query_url .= "&env=http://datatables.org/alltables.env";
$yql_query_url .= "&format=json";
$session = curl_init($yql_query_url);  
curl_setopt($session, CURLOPT_RETURNTRANSFER,true);      
$json = curl_exec($session);
$phpObj =  json_decode($json);  

if(!is_null($phpObj->query->results->span)){  
    foreach($phpObj->query->results->span as $result){  
        $_SESSION['price'] = $result;
  }  
}  
?>


<div> Ask:<?php echo $_SESSION['span'];?> </div>

yahooによって生成されたXMLは...です。

<query yahoo:count="1" yahoo:created="2012-05-16T19:00:25Z" yahoo:lang="en-US">
  <diagnostics>
    <publiclyCallable>true</publiclyCallable>
    <url execution-start-time="1" execution-stop-time="601" execution-time="600" proxy="DEFAULT">http://finance.yahoo.com/q?s=XAGUSD%3DX&ql=1</url>
    <user-time>613</user-time>
    <service-time>600</service-time>
    <build-version>27426</build-version>
  </diagnostics>
  <results><span id="yfs_g00_xagusd=x">28.3600</span></results>
</query>

本当にありがとうございました。よろしくお願いします。

4

1 に答える 1

1

クエリが壊れています。値は引用符で囲む必要があります。

$yql_query = "select * from html where url='$url' and xpath='$xpath';";

または、クエリ パラメータを介してこれらの値を提供することをお勧めします。

$yql_query = "select * from html where url=@url and xpath=@xpath;";
$params = array(
     'q'      => $yql_query,
     'url'    => $url,
     'xpath'  => $xpath,
     'env'    => 'http://datatables.org/alltables.env',
     'format' => 'json',
);
$yql_query_url = $yql_base_url . '?' . http_build_query($params);

本当に必要な結果を返す YQL を取得したら、探している価格が利用可能になります。

$phpObj->query->results->span->content

実行例を参照してください。

于 2012-05-16T20:02:16.370 に答える