加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何按IEnumerable属性值进行分组

发布时间:2020-12-15 23:25:05 所属栏目:百科 来源:网络整理
导读:可以说我有 class Class1 A { int Id; IEnumerableClass2 B;}class Class2 B { string Title;} 所以,如果我有(以json格式) {Id: 0,B: [{"Title": "a"},{"Title": "b"},{"Title": "c"} ]} 我想按标题分组,结果如此 { {"Id": 0,"Title": "a"},{"Id": 0,"Title"
可以说我有

class Class1 A {
    int Id;
    IEnumerable<Class2> B;
}

class Class2 B {
    string Title;
}

所以,如果我有(以json格式)

{Id: 0,B: [{"Title": "a"},{"Title": "b"},{"Title": "c"} ]}

我想按标题分组,结果如此

{ {"Id": 0,"Title": "a"},{"Id": 0,"Title": "b"},"Title": "c"} };

首选LINQ解决方案.试图做:

var result = A.GroupBy(x => x.B)

(我希望这不会起作用)和

var result = A.SelectMany(x => x.B).GroupBy(x => x)

但后来我只有头衔.我怎么能这样做?

解决方法

你没有分组,你正在做相反的事 – 扁平化 – 这是用SelectMany完成的:

A.SelectMany(a => a.B,(a,b) => new {a.Id,b.Title});

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读