Linq 查询到 Json 字符串



从 JObject 开始,我可以得到我感兴趣的数组:

JArray partial = (JArray)rssAlbumMetadata["tracks"]["items"];

第一个问题:"部分"包含了很多我不感兴趣的属性。我怎样才能只得到我需要的东西?

第二个问题:一旦第一个任务成功,我将获得重复项目的JArray。我怎样才能只得到独特的?结果应该是这样的

{
'composer': [
                {
                'id': '51523',
                'name': 'Modest Mussorgsky'
                },
                {
                'id': '228918',
                'name': 'Sergey Prokofiev'
                },
        ]
}

让我从这样的事情开始:

[
  {
    "id": 32837732,
    "composer": {
      "id": 245,
      "name": "George Gershwin"
    },
    "title": "Of Thee I Sing: Overture (radio version)"
  },
  {
    "id": 32837735,
    "composer": {
      "id": 245,
      "name": "George Gershwin"
    },
    "title": "Concerto in F : I. Allegro"
  },
  {
    "id": 32837739,
    "composer": {
      "id": 245,
      "name": "George Gershwin"
    },
    "title": "Concerto in F : II. Adagio"
  }
]

第一个问题:

我怎样才能只得到我需要的东西?

没有魔法,您需要读取整个 JSON 字符串,然后查询对象以找到您要查找的内容。如果需要,则无法读取部分 JSON。您尚未提供数据外观的示例,因此无法指定如何查询。

我想的第二个问题是:如何删除对象数组的重复内容?

同样,我没有您的对象的完整视图,但此示例应该能够向您展示 - 按照您的要求使用 Linq:

var items = new []{new {id=1, name="ali"}, new {id=2, name="ostad"}, new {id=1, name="ali"}};
var dedup = items.GroupBy(x=> x.id).Select(y => y.First()).ToList();
Console.WriteLine(dedup);

相关内容

  • 没有找到相关文章

最新更新