我有一个对象列表,每个类型都有一个常量值属性。例如:
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
答案 0 :(得分:1)
您可以按类型对对象进行分组,并获取每组中的第一个:
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
答案 1 :(得分:1)
在 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。
如果要维护不同对象类型的列表,可以将其拆分为单独的步骤。