【问题标题】:sum value and remove duplicates in List<> [duplicate]对 List<> 中的值求和并删除重复项 [重复项]
【发布时间】:2018-11-16 16:54:46
【问题描述】:

我想检查列表中的重复值并将价格汇总在一起。

按照下面的示例进行操作。

例如

var list = new List<Item>();
list.Add(new Item() { code= "521523", text= "cookie", price= 5});
list.Add(new Item() { code= "521523", text= "donut", price= 20 });
list.Add(new Item() { code= "521524", text= "coffee", price= 15 });
list.Add(new Item() { code= "521524", text= "water", price= 16 });
list.Add(new Item() { code= "521525", text= "other", price= 16 });

结果

code= "521523", text= "cookie", price= 25
code= "521524", text= "coffee", price= 31
code= "521525", text= "other", price= 16

【问题讨论】:

标签: c# asp.net


【解决方案1】:

你可以使用GroupBy:

list = list 
   .GroupBy(i => i.code)
   .Select(g => new Item
    { 
       code = g.Key, 
       text = String.Join(",", g.Select(i => i.text)), // join better than taking First()
       price = g.Sum(i => i.price)
    })
    .ToList();

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-12-29
    • 1970-01-01
    • 1970-01-01
    • 2019-10-13
    • 1970-01-01
    • 2014-11-11
    • 1970-01-01
    相关资源
    最近更新 更多