我在反序列化以下JSON结构时遇到问题。每个节点都包含一个ID和多个带有值的语言代码。语言属性的数量不一致。但我需要这些值作为具有语言字段和值字段的对象列表。
[{
"id":"w_312457",
"eng":"deep-fat frying",
"ger":"Frittieren"
},
{
"id":"w_312458",
"fre":"frying",
"ger":"braten (in Öl)"
},
{
"id":"w_312477",
"ger":"perfekt gewürzte und abgestimmte Soße "
}]
我尝试使用JsonPropertyName
属性,我获得了ID值。但对于lang节点,我不知道我可以指定什么名称。以下是我的CLR对象,
public class Word
{
public string Id { get; set; } // This is working
// What can I specify here. I need a list of objects each with a lang code and value.
}
答案 0 :(得分:2)
方法1:
一种方法是简单地添加所有值并检查它们是否存在。例如,这是包含所有语言值的类:
public class Word
{
public string id { get; set; }
public string eng { get; set; }
public string ger { get; set; }
public string fre { get; set; }
}
你得到的列表如下:
var words = JsonConvert.DeserializeObject<List<Word>>(json);
当然这假设只有3种语言而且不会添加更多语言(这种情况永远不会发生!)
方法2:
如this线程所示,您可以反序列化为这样的字典对象列表:
var words = JsonConvert.DeserializeObject<List<Dictionary<string, string>>>(json);
您可以访问所有键和值:
foreach (var word in words)
{
foreach (var key in word.Keys)
{
Console.WriteLine($"value for the key {key} is {word[key]}");
}
}
这将产生以下结果:
密钥id的值是w_312457
关键英文的价值是深油炸
关键ger的值是Frittieren
密钥id的值是w_312458
密钥fre的值正在煎炸
关键ger的值是braten(在Öl中)
密钥id的值是w_312477
关键ger的值是perfektgewürzteundabgestimmteSoße