我有一个json块,像这样:
{
"ADDRESS_MAP":{
"ADDRESS_LOCATION":{
"type":"separator",
"name":"Address",
"value":"",
"FieldID":40
},
"LOCATION":{
"type":"locations",
"name":"Location",
"keyword":{
"1":"LOCATION1"
},
"value":{
"1":"United States"
},
"FieldID":41
},
"FLOOR_NUMBER":{
"type":"number",
"name":"Floor Number",
"value":"0",
"FieldID":55
},
"self":{
"id":"2",
"name":"Address Map"
}
}
}
我如何获得这个令牌包含的所有关键项。例如,从上面的代码,我想有"address_location","LOCATION","FLOOR_NUMBER"one_answers"self"。
您可以将JToken
转换为JObject
,然后使用Properties()
方法获得对象属性列表。从那里,您可以很容易地获得名称。
像这样:
string json =
@"{
""ADDRESS_MAP"":{
""ADDRESS_LOCATION"":{
""type"":""separator"",
""name"":""Address"",
""value"":"""",
""FieldID"":40
},
""LOCATION"":{
""type"":""locations"",
""name"":""Location"",
""keyword"":{
""1"":""LOCATION1""
},
""value"":{
""1"":""United States""
},
""FieldID"":41
},
""FLOOR_NUMBER"":{
""type"":""number"",
""name"":""Floor Number"",
""value"":""0"",
""FieldID"":55
},
""self"":{
""id"":""2"",
""name"":""Address Map""
}
}
}";
JToken outer = JToken.Parse(json);
JObject inner = outer["ADDRESS_MAP"].Value<JObject>();
List<string> keys = inner.Properties().Select(p => p.Name).ToList();
foreach (string k in keys)
{
Console.WriteLine(k);
}
输出:ADDRESS_LOCATION
LOCATION
FLOOR_NUMBER
self
除了已接受的答案之外,我还想给出一个显示如何直接迭代Newtonsoft集合的答案。它使用更少的代码,我猜它更有效,因为它不涉及转换集合。
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
//Parse the data
JObject my_obj = JsonConvert.DeserializeObject<JObject>(your_json);
foreach (KeyValuePair<string, JToken> sub_obj in (JObject)my_obj["ADDRESS_MAP"])
{
Console.WriteLine(sub_obj.Key);
}
我自己开始这样做,因为JsonConvert自动将嵌套对象反序列化为JToken(我认为下面是JObject, JValue或JArray)。
我认为解析工作遵循以下原则:
每个对象都被抽象为JToken
如果JToken代表终端节点并且是一个值,则转换为JValue
转换为JArray如果它是一个数组
JValue。值给出你需要的。net类型
如果你知道json的结构,你收到然后我建议有一个类结构,反映你在json中收到的。
那么你可以这样称呼它…
AddressMap addressMap = JsonConvert.DeserializeObject<AddressMap>(json);
(其中json是包含json的字符串)
如果你不知道你收到的json的格式,那么它会变得有点复杂,你可能需要手动解析它。
查看http://www.hanselman.com/blog/NuGetPackageOfTheWeek4DeserializingJSONWithJsonNET.aspx获取更多信息