我有一个对象列表,每个类型都有一个常量值属性。例如:
ObjectA : { Value: 5 }
ObjectB : { Value: 15 }
ObjectC : { Value: 2 }
在我的对象列表中,这些对象可以多次出现:
List<object> objects = new List<object> { ObjectA, ObjectA, ObjectB, ObjectC, ObjectC, ObjectC};
现在我想对所有对象求和(按属性值),但我想要一个不同对象的列表,如下所示:
List<object> objects = new List<object> { ObjectA, ObjectB, ObjectC };
我怎么才能意识到这一点呢?Distinct()在这种情况下不起作用。
提前感谢!Yheeky
发布于 2015-10-29 19:24:55
您可以按对象的类型对对象进行分组,并获取每个组中的第一个:
var result = objects.GroupBy(o => o.GetType())
.Select(g => g.First());
我不确定您所说的求和所有对象(按属性值)是什么意思,但您也可以这样做:
var result = objects
.GroupBy(o => o.GetType())
.Select(g => new
{
Object = g.Key.Name,
Sum = g.Sum(x => (int)(g.Key.GetProperty("Value")
.GetValue(x)))
});
这将给出如下输出:
ObjectA 12
ObjectB 60
ObjectC 24
发布于 2015-10-29 21:50:46
在Gert Arnold的答案上稍作扩展,下面是如何使用dynamics从不同的对象类型列表中获得和:
var a1 = new ObjectA(); //Value is 5
var a2 = new ObjectA(); //Value is 5
var b = new ObjectB(); //Value is 15
var c = new ObjectC(); //Value is 2
var list = new List<dynamic> { a1, a2, b, c };
var result = list
.GroupBy(d => d.GetType())
.Select(g => g.First())
.Sum(d => d.Value);
结果值是22,而不是27。
如果您想要维护不同对象类型的列表,则可以将其拆分为单独的步骤。
https://stackoverflow.com/questions/33422862
复制相似问题