c# - Google 财经,如何获取流式传输的 JSON 数据?

标签 c# ajax json google-finance

我之前试图解释这一点,但显然失败了!

因此,如果您打开了一个 google finance 图表,例如:

http://www.google.com/finance?q=INDEXNASDAQ:.IXIC

我想以某种方式在 C# 中使用 (HttpWebRequest) 对象,以便我可以获取 google 发送到页面以更新图形的小数据。

friend 提到这是 JSON?

我尝试使用以下代码示例,但即使我将 keep alive 属性设置为“true”,它仍然无法工作:

http://msdn.microsoft.com/en-us/library/system.net.httpwebrequest.keepalive.aspx#Y369

最佳答案

您还需要更改示例中将 Connection 属性设置为 Close 的行。注释掉这一行(同时保持 keep-alive 属性设置为 true):

myHttpWebRequest2.Connection = "Close";

您这样做,您的示例应该可以正常运行。

关于获取数据并使用 HttpWebRequest 来处理它,您可以这样做。返回的数据不是 JSON - 它看起来像纯文本,我猜 Google 的 javascript 正在解析它。 (我没有检查过 Google 财经页面上的 javascript,但这是我的猜测。)

使用 Fiddler,来自此 URL 的响应:

http://www.google.com/finance/getprices?q=.IXIC&x=INDEXNASDAQ&i=120&p=10m&f=d,c,v,o,h,l&df=cpct&auto=1&ts=1307994768643

看起来像这样:

EXCHANGE%3DINDEXNASDAQ
MARKET_OPEN_MINUTE=570
MARKET_CLOSE_MINUTE=960
INTERVAL=120
COLUMNS=DATE,CLOSE,HIGH,LOW,OPEN,VOLUME
DATA=
TIMEZONE_OFFSET=-240
a1307994120,2641.12,2641.12,2639.96,2640.01,0
1,2638.76,2642.14,2638.76,2641.13,0
2,2638.95,2640.54,2638.74,2638.79,0
3,2639.85,2640.01,2638.08,2638.95,0
4,2640.07,2640.87,2639.31,2639.88,0
5,2640.31,2640.48,2639.42,2640.08,0
6,2641.09,2641.09,2640.3,2640.31,0

有点神秘,但您可以看到 COLUMNS 行如何与底部的数据对齐。此外,f 查询字符串参数似乎指示要返回哪些列(d=date、c=close、v=volume、o=open、h=high、l=low)。

编辑:我应该提一下,我使用的 URL 是从财务图表页面发送的,以获取更新的数据 - 您可以看到使用 Fiddler 等工具定期请求此 URL。我上面粘贴的响应数据也由 MSDN 的示例应用程序输出。

但注释掉来自 MSDN 的示例中的那一行并稍微摆弄一下 Fiddler 应该会为您提供解析来自该 URL 的返回值所需的数据和线索。

希望对您有所帮助!

PS - 我修改后的 MSDN 示例中的第一行如下所示:

HttpWebRequest myHttpWebRequest1 = (HttpWebRequest)WebRequest.Create("http://www.google.com/finance/getprices?q=.IXIC&x=INDEXNASDAQ&i=120&p=10m&f=d,c,v,o,h,l&df=cpct&auto=1&ts=1307994768643");

我在示例中对另一个 WebRequest 调用做了类似的更改...除此之外,我没有更改示例中的任何其他内容。

关于c# - Google 财经,如何获取流式传输的 JSON 数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6335121/

相关文章:

c# - DI,从工厂解决服务实现

php - 带宽与数据库查询

javascript - 创建复选框数组并将其传递给 JavaScript 函数

javascript - WP-json 未使用 angularJS 显示

c# - 在 .net 中有很好的解释和示例的控制/依赖注入(inject)的反转?

c# - 为什么我的 Base64 编码哈希只包含 28 个字符?

sql - 将 SQL ResultSet 转换为 json

json - 如何在 Flutter 中的轮播( slider )中显示来自 JSON 文件的图像

c# - 如何将运行时参数作为依赖项解析的一部分传递?

javascript - JSONArray JSP Ajax Jquery