質問

Google Finance APIを使用して、ストック情報を正常に収集しています。問題は、電話後のことです http://www.google.com/finance/info?infotype=infoquoteall&q=[$tickerSymbol], 、Googleが返すJSONが持っています // それ以前に追加されるため、PHPを使用して文字列をエンコードすることはできません json_encode(). 。 Jsonlint JSon Validator それを確認します //Sは無効です。明らかな回避策は、JSONの最初からスラッシュを剥奪することです。それにもかかわらず、私はGoogleがなぜJSONにスラッシュを追加しているのか疑問に思っています。余分なスラッシュの背後に目的はありますか?これはPHPのある癖ですか json_encode() 他の言語が単に余分な文字を無視するときはいつですか?私は間違って何かをしていますか?

これは、のリクエストの結果の例です http://www.google.com/finance/info?infotype=infoquoteall&q=AAPL 主要なスラッシュで。

// [ {
"id": "22144"
,"t" : "AAPL"
,"e" : "NASDAQ"
,"l" : "340.65"
,"l_cur" : "340.65"
,"ltt":"4:00PM EST"
,"lt" : "Jan 18, 4:00PM EST"
,"c" : "-7.83"
,"cp" : "-2.25"
,"ccol" : "chr"
,"el": "345.20"
,"el_cur": "345.20"
,"elt" : "Jan 18, 5:45PM EST"
,"ec" : "+4.55"
,"ecp" : "1.34"
,"eccol" : "chg"
,"div" : ""
,"yld" : ""
,"eo" : ""
,"delay": ""
,"op" : "327.05"
,"hi" : "344.76"
,"lo" : "326.00"
,"vo" : "66.34M"
,"avvo" : "11.28M"
,"hi52" : "348.48"
,"lo52" : "190.25"
,"mc" : "313.75B"
,"pe" : "22.49"
,"fwpe" : ""
,"beta" : "1.38"
,"eps" : "15.15"
,"name" : "Apple Inc."
,"type" : "Company"
}
]
役に立ちましたか?

解決

すぐに回答を求めている人のために、PHPの実用的な例です。 JSONはクリーニングされ、オブジェクトに変換されます。値は簡単に抽出できます。

2つ目は、それをより素晴らしいものにするためだけに、ページにアクセスしたときにPubnubチャンネルを押したメッセージを送信します(Cronはあなたの友人です)。 pubnubメッセージはJavaScriptを介して簡単に受信できます。

<?php

  //Obtain Quote Info
  $quote = file_get_contents('http://finance.google.com/finance/info?client=ig&q=INDEXDB:DAX');

  //Remove CR's from ouput - make it one line
    $json = str_replace("\n", "", $quote);

  //Remove //, [ and ] to build qualified string  
    $data = substr($json, 4, strlen($json) -5);

  //decode JSON data
    $json_output = json_decode(utf8_decode($data));

  // get the last price
    $last = $json_output->l;

  //Output Stock price .
  echo 'DAX: ' . $last; 


//////////////////////////////
//  send it through pubnub  //
//////////////////////////////

require_once('Pubnub.php');

// Publish and Subscribe Keys 
$publish_key   = 'demo';
$subscribe_key = 'demo';
$subscribe_key = false;

// Create Pubnub Object
$pubnub = new Pubnub( $publish_key, $subscribe_key, $secret_key );

// Publish !
$channel = 'quoteTheDax';

$timestamp = $pubnub->time();
$pubish_success = $pubnub->publish(array(
    'channel' => $channel,
    'message' => array("last" => $last2, "ts" => $timestamp)
));

//Boom its send to ppl subscribed to this channel arround the world
?>

もちろん、常に何かをライブ更新する必要がある場合は、より良いオプションがあります。 30分/60分ごとに更新しようとしていました。

他のヒント

GoogleがあなたがそのJSONと一緒に仕事をしていることを望んでいないからだと思います。彼らはGoogle Data APIを使用することをお勧めします。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top