0

构造 linq 语句(C#,查询语法,但我可以处理方法语法)有点麻烦。它需要支持分组以及公开计算的属性。我对每一个都有处理,但无法让它们看起来一起工作。任何帮助,将不胜感激。

数据

GrpField          Qty      Price
-------------     ---      -----
RED                1        10
RED                2        10
RED                1        50
BLUE               2        30
BLUE               2        50

输出需要是每个组的总价格(数量 * 价格)的总和

期望的结果

RED    80
BLUE  160

这让我得到了总价线

from x in origdata
let linetotal = x.qty * x.price
select new { x.grpfield, x.qty, x.price, linetotal } 

但是我无法按新的匿名类型进行分组,因为您无法在匿名类型上运行 sum 之类的聚合。如果我先运行该组,我无法弄清楚如何在总和之前将 linetotal 加入到组合中。

4

3 回答 3

4

作为反对你的证据,因为你不能在匿名类型语句上运行 sum 这样的聚合......

var data = new[]
    {
        new {GrpField = "RED", Qty = 1, Price = 10},
        new {GrpField = "RED", Qty = 2, Price = 10},
        new {GrpField = "RED", Qty = 1, Price = 50},
        new {GrpField = "BLUE", Qty = 2, Price = 30},
        new {GrpField = "BLUE", Qty = 2, Price = 50},
    };

var grouped =
    from d in data
    group d by d.GrpField
    into g
    select new {Group = g.Key, Sum = g.Sum(x => x.Qty * x.Price)};

foreach(var g in grouped)
    Console.WriteLine("{0} - {1}", g.Group, g.Sum);
于 2012-10-05T15:16:56.997 回答
2

先分组,再求和。

origdata.GroupBy(m => m.GrpField)
 .Select(group => new {
     GrpField = group.Key,
     CalculatedValue = group.Sum(m => m.qty * m.price)
  });
于 2012-10-05T15:10:23.273 回答
1
origdata.GroupBy(p=>p.GrpField)
.Select(p=> new()
{
    GrpField=p=>p.Key,
    Sum=p.Sum(q=>q.Qty*q.Price)
})
于 2012-10-05T15:12:33.440 回答