首页 > 解决方案 > 根据属性值从 JObject 返回子对象

问题描述

我有一些 JSON,如下所示。我想从中获取“类型”为“项目”的所有对象。

 string json = @"
        {
            'name': 'Object 1',
            'content': {
                'body': {
                    'id': 'body',
                    'type': 'Body'
                },
                'style': {
                    'id': 'style',
                    'type': 'Style'
                },
                'DynamicName-123': {
                    'id': 'DynamicName-123',
                    'type': 'Row'
                },
                'DynamicName-434': {
                    'id': 'DynamicName-434',
                    'type': 'Column'
                },
                'DynamicName-223': {
                    'id': 'DynamicName-223',
                    'type': 'Item'
                }
            }
        }";

JObject obj = JObject.Parse(json);

预期输出:

'id': 'DynamicName-223',
'type': 'Item'

我怎样才能做到这一点?

标签: c#jsonlinqjson.net

解决方案


您可以使用如下所示的LINQ-to-JSON查询来获取“类型”属性值为“Item”的对象:

JObject obj = JObject.Parse(json);

List<JObject> items = obj["content"]
    .Children<JProperty>()
    .Where(p => (string)p.Value["type"] == "Item")
    .Select(p => (JObject)p.Value)
    .ToList();

小提琴:https ://dotnetfiddle.net/dy1nQC


推荐阅读