我有这个JSON,我必须反序列化它:
{
"homepage": "http://files.minecraftforge.net/maven/net/minecraftforge/forge/",
"promos": {
"1.10-latest": "12.18.0.2000",
"1.10.2-latest": "12.18.1.2014",
"1.10.2-recommended": "12.18.1.2011",
"1.5.2-latest": "7.8.1.738",
"1.5.2-recommended": "7.8.1.737",
"1.6.1-latest": "8.9.0.775",
"1.6.2-latest": "9.10.1.871",
"1.6.2-recommended": "9.10.1.871",
"1.6.3-latest": "9.11.0.878",
"1.6.4-latest": "9.11.1.1345",
"1.6.4-recommended": "9.11.1.1345",
"1.7.10-latest": "10.13.4.1614",
"1.7.10-latest-1.7.10": "10.13.2.1343",
"1.7.10-recommended": "10.13.4.1558",
"1.7.2-latest": "10.12.2.1147",
"1.7.2-recommended": "10.12.2.1121",
"1.8-latest": "11.14.4.1577",
"1.8-recommended": "11.14.4.1563",
"1.8.8-latest": "11.15.0.1655",
"1.8.9-latest": "11.15.1.1902",
"1.8.9-recommended": "11.15.1.1722",
"1.9-latest": "12.16.0.1942",
"1.9-recommended": "12.16.1.1887",
"1.9.4-latest": "12.17.0.1990",
"1.9.4-recommended": "12.17.0.1976",
"latest": "12.18.1.2014",
"latest-1.7.10": "10.13.2.1343",
"recommended": "12.18.1.2011"
}
}
在这个网站上搜索了很多,我推出了这段代码:
dynamic json = JsonConvert.DeserializeObject<Dictionary<string, string>>(data);
foreach (KeyValuePair<string, string> entry in json["promos"])
{
MessageBox.Show(entry.Key);
MessageBox.Show(entry.Value);
}
我需要从Json获得Key和Value,但是使用这段代码,它表示第3行pos 13上有一个意想不到的字符。 我尝试了很多不同的方式,但我不能同时获得价值和关键。有了一些代码,我只得到了密钥和其他一些代码,我只得到了价值。你能解释一下如何获得价值和关键吗?
答案 0 :(得分:4)
您可以直接将json解析为JObject并转换节点&#34; promos&#34;到词典
var json = JObject.Parse(data);
var promos = json["promos"].ToObject<Dictionary<string, string>>();
foreach (var entry in promos)
{
MessageBox.Show(entry.Key);
MessageBox.Show(entry.Value);
}
答案 1 :(得分:0)
问题是您尝试反序列化的类型。 你试图将它反序列化为一个字典,但是第一个条目是一对字符串,promos就是一个字典本身,所以你不能投出&#34; promos&#34;串! 假设您的json位于名为&#34; json.json&#34;的文件中。您可以通过迭代promos JObject获取一个Dictionary,并以这种方式将您获得的项目转换为JProperty:
var json = File.ReadAllText("json.json");
var deserialized = JsonConvert.DeserializeObject<JObject>(json);
var dictionary = new Dictionary<string, string>();
foreach (JProperty item in deserialized["promos"])
dictionary.Add(item.Name, item.Value.ToString());
答案 2 :(得分:0)
您的数据不是Dictionary<string, string>
,因为promos
的值不是string
而是字典。
您可以反序列化为JObject
,然后获取promos
属性的值。
JObject json = JsonConvert.DeserializeObject<JObject>(data);
//var promos = json.Value<Dictionary<string, string>>("promos");
var promos = data["promos"].ToObject<Dictionary<string, string>>();
foreach (KeyValuePair<string, string> entry in promos) {
//do some stuff
}
修改
不确定,为什么原始方式不起作用,现在没有时间进行调查,但第二行应该这样做。