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>
本当にありがとうございました。よろしくお願いします。