C#反序列化Json未知密钥

时间:2016-07-16 12:44:17

标签: c# json visual-studio json.net

我有这个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上有一个意想不到的字符。 我尝试了很多不同的方式,但我不能同时获得价值和关键。有了一些代码,我只得到了密钥和其他一些代码,我只得到了价值。你能解释一下如何获得价值和关键吗?

3 个答案:

答案 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
}

修改

不确定,为什么原始方式不起作用,现在没有时间进行调查,但第二行应该这样做。