根据唯一性对列表进行分组

Roc*_*art 6 c# linq lambda list

这个问题是一个略微修改过的版本 转换列表<T>到带有策略的字典

我有List <DTO>,其中DTO类看起来像这样,

private class DTO
    {
        public string Name { get; set; }
        public int Count { get; set; }
    }
Run Code Online (Sandbox Code Playgroud)

我创建对象并将其添加到List.

var dto1 = new DTO { Name = "test", Count = 2 };
var dto2 = new DTO { Name = "test", Count = 3 };
var dtoCollection = new List<DTO> {dto1, dto2};
Run Code Online (Sandbox Code Playgroud)

现在我的要求是我需要从dtoCollection创建一个List,其中Name字段在整个List中应该是唯一的.

例如,如果将上面的dtoCollection转换为所需的List,则结果列表应如下所示:

列表<DTO>计数应为1;

列表中的对象应该是单个DTO,其名称为"test",Count为5

其中Count是通过总结名称字段相同的所有DTO中的Count字段获得的

Ani*_*Ani 6

尝试:

var result = dtoCollection.GroupBy(dto => dto.Name)
                          .Select(group => new DTO 
                                           {
                                               Name = group.Key,
                                               Count = group.Sum(dto => dto.Count) 
                                           })
                          .ToList();
Run Code Online (Sandbox Code Playgroud)

这通过按名称对DTO进行分组,然后从每个组中提取从组的键中命名的新DTO并将计数设置为其成员计数的总和来实现.

  • 干净的方式是将其提取到密钥中以及"GroupBy(dto => new {dto.Name,dto.Surname})",然后从组中提取密钥的两个组成部分.但由于您确信姓氏对于名称是唯一的,您还可以使用我的原始代码提取该组第一个成员的姓氏:`[...],Surname = group.First().姓氏,[...]`. (2认同)

L.B*_*L.B 3

var newList = dtoCollection.GroupBy(d => d.Name)
             .Select(g => new DTO(){ Name=g.Key, Count=g.Select(d => d.Count).Sum()})
             .ToList();
Run Code Online (Sandbox Code Playgroud)