【发布时间】:2016-01-03 13:09:56
【问题描述】:
最近我得到一个约会,我需要使用它的 REST API 从云下载一些数据,并将该“字符串”中的值存储在一个对象或一些变量中。下载完成,我现在需要做的就是以某种方式解析数据。
直到现在我制作了这种代码:
HttpWebRequest request = (HttpWebRequest)WebRequest.Create("some link");
request.ContentType = "application/json; charset=utf-8";
request.Method = "GET";
request.Headers.Add("Carriots.apiKey", "key");
using (WebResponse response = request.GetResponse())
{
using(Stream stream = response.GetResponseStream())
{
StreamReader reader = new StreamReader(stream);
JObject json = JObject.Parse(reader.ReadToEnd());
Console.WriteLine(json.ToString());
}
}
这是输出:
{
"total_documents": 3,
"result": [
{
"_id": "...",
"protocol": "v1",
"checksum": "",
"_t": "str",
"at": 1444134377,
"device": "-just a device-",
"data": {
"field1": "123",
"field2": "1536"
},
"id_developer": "....",
"created_at": 1444134377,
"owner": "-someUser-"
}
]
}
我知道互联网上有很多解决方案,但没有一个能满足我的需要。好的,我找到了一些东西,但它会在每一行上迭代并以这种方式检查值,但在我的情况下,我可以有数千个这样的输出。
有没有办法使用某种内置函数来完成所有这些(我的意思是解析),或者唯一的解决方案是迭代或编写一些正则表达式?
【问题讨论】:
-
你是用 c# 还是 js 读那个 JSON?
-
反序列化就是你要找的东西!
-
试用 Linq to Json newtonsoft.com/json/help/html/LINQtoJSON.htm
-
可能相关:JObject.Parse vs JsonConvert.DeserializeObject(
JObject.Parse是 Newtonsoft Json.Net) -
可能重复。看看this post