当第一个字段的名称为动态时,从JSON中获取值

时间:2019-06-25 00:54:16

标签: c# json

在这里以List<string>检索值的最佳方法是什么? 我无法将其转换为具体的类,因为根对象的名称将始终更改。

以下是json:

{"356bfd81-0fd7-45ef-a768-d0d1b6f63c1b":{"TableEntry":[{"Id":"169b47a6-1f94-4103-959b-785096960927"},{"Id":"e07885eb-0db5-4134-8890-681a8fa63a8e"},{"Id":"12fe4ad1-cf22-40ea-840f-356bfd0b6ce2"},{"Id":"1a4ec0d6-f2b6-43e2-adc6-7350ea0dc9c7"},{"Id":"16cbecd7-80a5-43f8-b83a-54816b2bff87"},{"Id":"c1df10c6-0628-4844-9024-f43f9a3605c7"},{"Id":"bdced1ae-203c-4c9e-bc8e-d4d74b9008f3"},{"Id":"50e9e85e-cd3c-4a49-820d-607960e81e87"},{"Id":"1869b251-ffce-474e-bedb-3f37a07e36e2"},{"Id":"8e8c432b-0d7a-4397-b96b-c77a93692941"}]}}

我不知道如何绕过第一个根对象来获取我想要的ID列表。

到目前为止,我已经尝试过JObject.Parse(),但这只允许我使用.First属性。但这会使我的变量看起来像myObject.First.First.First。这不理想。

我还尝试过将其转换为dynamic。但这也不好,我不能去myObject.TableEntry-它看不到。而且我似乎无法通过这里的第一点,因为myObject[0]会引发异常。

任何建议如何从这样的json获取List<string>的ID? 谢谢。

2 个答案:

答案 0 :(得分:2)

在模型中使用Dictionary<string,YourModel>

public class MyModel {
    public TableEntry[] TableEntry { get; set; }
}

public class TableEntry {
    public string Id { get; set; }
}

一旦解析

var data = JsonConvert.DeserializeObject<Dictionary<string,MyModel>>(json);

您可以轻松获取数据

List<string> ids = data.First().Value.TableEntry.Select(entry => entry.Id).ToList();

List<string> ids = data
    .SelectMany(kvp => kvp.Value.TableEntry.Select(entry => entry.Id))
    .ToList();

如果有多个动态键

答案 1 :(得分:0)

如果只有这些对象的键为Id,则另一种方法是使用Descendants()。

JToken Id = null;
var jsonObject = JObject.Parse(json);
List<string> IDs = jsonObject.Descendants().Where(x => d is JObject && ((JObject)d).TryGetValue("Id", out Id)).Select(_=>Id.Value<string>()).ToList();