微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

这个问题是 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();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐