我有List< DTO> DTO类看起来像这样,
private class DTO { public string name { get; set; } public int Count { get; set; } }
我创建对象并将其添加到List.
var dto1 = new DTO { name = "test",Count = 2 };var dto2 = new DTO { name = "test",Count = 3 };var dtoCollection = new List<DTO> {dto1,dto2};
现在我的要求是我需要从dtoCollection创建一个List,其中name字段在整个List中应该是唯一的.
例如,如果将上面的dtoCollection转换为所需的List,则结果列表应如下所示:
列表< DTO>计数应为1;
列表中的对象应该是单个DTO,其名称为“test”,Count为5
其中Count是通过总结名称字段相同的所有DTO中的Count字段获得的
解决方法var newList = dtoCollection.GroupBy(d => d.name) .Select(g => new DTO(){ name=g.Key,Count=g.Select(d => d.Count).Sum()}) .ToList();总结
以上是内存溢出为你收集整理的c# – 根据唯一性对列表进行分组全部内容,希望文章能够帮你解决c# – 根据唯一性对列表进行分组所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)