首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调用Google Finance Options API URL

调用Google Finance Options API URL
EN

Stack Overflow用户
提问于 2017-01-12 09:22:17
回答 1查看 1.1K关注 0票数 0

在浏览器中键入此命令会自动下载一个txt文件,该文件是AAPL股票期权数据的json格式文本。

http://www.google.com/finance/option_chain?q=AAPL&output=json

我想把这些数据直接放到一个Javascript变量中,这样我就可以解析结果并在浏览器中显示数据。

我试过了:

代码语言:javascript
复制
$.getJSON('http://www.google.com/finance/option_chain?q=AAPL&output=json', function(json) {
      console.log(json);
    });

但我得到了No 'Access-Control-Allow-Origin' header is present on the requested resource.错误,就像在其他帖子中看到的那样。

我也尝试过使用ajax:

代码语言:javascript
复制
$.ajax({
  dataType: "json",
  url: "http://www.google.com/finance/option_chain?q=AAPL&output=json",
}).done(function ( data ) {
  console.log(data);
});

但是得到了相同的错误。

我也尝试过在url中使用jsonp (&output=jsonp),但得到了一个Uncaught SyntaxError: Unexpected token )错误,在Chrome检查器中返回();

如何将这些json数据从Google直接拉到JS中?

EN

回答 1

Stack Overflow用户

发布于 2017-01-16 23:48:03

我相信有更好的方法...但它是有效的。

首先,要解决跨域请求,您可以使用YQL。则url答案不是有效的json字符串。所以我使用"eval“来执行响应文本,并将其存储在tmp变量中。

代码语言:javascript
复制
function toYQL(site){
    return 'http://query.yahooapis.com/v1/public/yql?q=' +
        encodeURIComponent('select * from html where url="' + site + '"') +
        '&format=json&callback=?';
}
$.ajax({
  dataType: "json",
  url: toYQL("http://www.google.com/finance/option_chain?q=AAPL&output=json"),
  success: function(response){
      eval("var tmp=" + response.query.results.body);
      console.log(tmp);
  }
})

这就对了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41603625

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档