【问题标题】:Deserialize dynamically named JSON objects in C# (using JSON.Net or otherwise)在 C# 中反序列化动态命名的 JSON 对象(使用 JSON.Net 或其他方式)
【发布时间】:2013-02-20 01:19:29
【问题描述】:

我有以下 JSON:

{
"aaaa": {
    "name": "General Name",
    "product": "book",
    "host": "book.example.com",
    "chapters": {
        "bbbb": {
            "name": "Chapter 1",
            "page": "1",
            "end_page": "25"
        }
    },
    "categories" : {
        "analysis":{
            "Abbbb" : {
                    "name": "B Chapter",
                    "id" : "9001"
            },
            "Acccc" : {
                    "name": "C Chapter",
                    "id" : "9001"
            },
            "Adddd" : {
                    "name": "D Chapter",
                    "id" : "9001"
            },
            "Aeeee" : {
                    "name": "E Chapter",
                    "id" : "9001"
            },
            "Affff" : {
                    "name": "F Chapter",
                    "id" : "9001"
            },
            "Agggg" : {
                    "name": "G Chapter",
                    "id" : "9001"
            }
        },
        "sources":{
            "acks" : {
                    "name": "S. Spielberg",
                    "id" : "9001"
            }
        }
    }
}
"yyyy": {
    "name": "Y General Name",
    "product": "Y book",
    "host": "ybook.example.com",
    ...
}
"zzzz": {
    "name": "Z General Name",
    "product": "Z book",
    "host": "zbook.example.com",
    ...
}

aaaayyyyzzzz 的值可以是任意字符串,并且可以有任意数量。

我需要提取所有 [aaaa|yyyy|zzz].categories.analysis 值。也就是说,我需要以 object 名称(例如,AbbbbAcccc 等)和 ID 结束 Dictionary<string, string>,忽略 name 字符串。

例如, [艾伯,9001] [ACCCC,9001] [添加,9001] ... [Zaaaa,9001]

我在这方面已经太久了,感觉我错过了一些明显的东西。我已经尝试过 JSON.net 和本机序列化。在我使用过的所有其他语言中,这都是一项微不足道的任务。

我已经接近了这样的事情:

var ajsonObject = JsonConvert.DeserializeObject<dynamic>(jsonString);
var oasearch_categories = ajsonObject.aaaa.categories.analysis;

但同样,aaaa 可以是任何字符串,所以我不确定如何动态引用它。

【问题讨论】:

    标签: c# .net json serialization json.net


    【解决方案1】:

    花了一段时间,但我想通了。我的要求与最初的问题略有不同......我的最终结果需要一个列表字典,所以我最终会得到一个字典:

    DICT[ {"9001", ["Abbbb", "Acccc", "Adddd", ...]}, {"9002", ["Zbbbb, Zdddd", ...]}, etc. ]
          | key |  |          value               |   | key |  |       value       |
    

    这是结果:

    Dictionary<string, List<string>> idsAndTheirNames = new Dictionary<string, List<string>>();
    
    try
    {
        var ajsonObject = JsonConvert.DeserializeObject<dynamic>(JSONstring);
    
        foreach (var child in ajsonObject.Children())
        {
            foreach (var product in child.Children())
            {
                var categories = product.categories.analysis;
    
                foreach (var category in categories.Children())
                {
                    foreach (var subcat in category)
                    {
                        List<string> name = idsAndTheirNames[(string)subcat.id]; //e.g., "9001"
    
                        if (name == null) name = new List<string>();
    
                        name.Add(category.Name); //e.g., "Abbbb"
                        idsAndTheirNames[(string)subcat.id] = name; //"9001" -> ["Abbbb", "Acccc", etc.]
    
                        System.Diagnostics.Debug.WriteLine((string)category.Name);  //"Abbbb"
                        System.Diagnostics.Debug.WriteLine((string)subcat.name);    //"Chapter B"
                        System.Diagnostics.Debug.WriteLine((string)subcat.id);      //"9001"
                    }
                }
            }
        }
    }
    catch (Exception ex)
    {
        System.Diagnostics.Debug.WriteLine("JSON ERROR: " + ex.Message);
    }
    

    【讨论】:

      猜你喜欢
      • 2011-08-16
      • 2011-05-30
      • 2017-05-26
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多