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字段获得的
尝试:
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并将计数设置为其成员计数的总和来实现.
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)