这个问题是
Convert List<T> to Dictionary with strategy的略微修改版本
我有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();