LINQ查询获取所有类型的对象

时间:2015-10-29 19:20:21

标签: linq distinct

我有一个对象列表,每个类型都有一个常量值属性。例如:

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

2 个答案:

答案 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。

如果要维护不同对象类型的列表,可以将其拆分为单独的步骤。