使用LINQ

时间:2018-09-17 23:14:04

标签: c# json linq jsonparser

我是LINQ查询的新手,想知道是否可以通过LINQ查询实现我想要的目标。

因此,我有一个JSON文档,如下所示。

我试图获取与“ $ type” 匹配的所有值,并向我返回目录路径和$ type的值。

我知道执行此操作的交互式方式,但是LINQ似乎是首选,并且应该很容易实现。

{
   "$type":"type1",
   "title":"US version",
   "_object1":[
      {
         "$type":"type2",
         "rootModule":{
            "id":"page",
            "modules":[
               {
                  "id":"header",
                  "$type":"module-header"
               },
               {
                  "id":"footer",
                  "$type":"module-footer"
               }
            ]
         }
      },
      {
         "$type":"type2",
         "_id":"ab134"
      },
      {
         "$type":"type3",
         "_id":"ab567"
      }
   ],
   "_object2":[
      {
         "$type":"module1",
         "constraintsId":"page"
      },
      {
         "name":"header1 1",
         "nestedobject":{
            "$type":"nestedobject-type",
            "dataBinder":{
               "id":"ab244"
            }
         }
      }
   ]
}

1 个答案:

答案 0 :(得分:2)

谢谢大家

我能够得到如下列表:

    var root = (JContainer)JToken.FromObject(document, CommonSerializerSetting.GetCommonSerializer());
    var descendant = "$type";
    var query = root

        // Recursively descend the JSON hierarchy
        .DescendantsAndSelf()

        // Select all properties named descendant
        .OfType<JProperty>()
        .Where(p => p.Name == descendant)

        // Select their value
        .Select(p => p.Value);