web-dev-qa-db-ja.com

オブジェクトのC#リスト、プロパティの合計を取得する方法

オブジェクトのリストがあります。個々のオブジェクトエントリの1つのプロパティは金額です。金額の合計を取得するにはどうすればよいですか?

リストがdouble型の場合、次のようなことができるかもしれません。

double total = myList.Sum();

しかし、私はこれに似たものにしたいのですが、この構文は間違っています。

double total = myList.amount.Sum();

これを達成するにはどうすればよいですか?ループして値を計算する代わりに、可能であればSum関数を使用したいと思います。

130
Joseph U.
using System.Linq;

...

double total = myList.Sum(item => item.Amount);
262
Alex LE

そして、特定の条件に一致するアイテムでそれを行う必要がある場合...

double total = myList.Where(item => item.Name == "Eggs").Sum(item => item.Amount);
30
Greg Quinn

別の選択肢:

myPlanetsList.Select(i => i.Moons).Sum();
9
usefulBee

このようなテストを行うために実行できるコードの例を次に示します。

var f = 10000000;
var p = new int[f];

for(int i = 0; i < f; ++i)
{
    p[i] = i % 2;
}

var time = DateTime.Now;
p.Sum();
Console.WriteLine(DateTime.Now - time);

int x = 0;
time = DateTime.Now;
foreach(var item in p){
   x += item;
}
Console.WriteLine(DateTime.Now - time);

x = 0;
time = DateTime.Now;
for(int i = 0, j = f; i < j; ++i){
   x += p[i];
}
Console.WriteLine(DateTime.Now - time);

複雑なオブジェクトの同じ例は次のとおりです。

void Main()
{
    var f = 10000000;
    var p = new Test[f];

    for(int i = 0; i < f; ++i)
    {
        p[i] = new Test();
        p[i].Property = i % 2;
    }

    var time = DateTime.Now;
    p.Sum(k => k.Property);
    Console.WriteLine(DateTime.Now - time);

    int x = 0;
    time = DateTime.Now;
    foreach(var item in p){
        x += item.Property;
    }
    Console.WriteLine(DateTime.Now - time);

    x = 0;
    time = DateTime.Now;
    for(int i = 0, j = f; i < j; ++i){
        x += p[i].Property;
    }
    Console.WriteLine(DateTime.Now - time);
}

class Test
{
    public int Property { get; set; }
}

コンパイラーの最適化をオフにした私の結果は次のとおりです。

00:00:00.0570370 : Sum()
00:00:00.0250180 : Foreach()
00:00:00.0430272 : For(...)

2番目のテストは次のとおりです。

00:00:00.1450955 : Sum()
00:00:00.0650430 : Foreach()
00:00:00.0690510 : For()

lINQは一般にforeach(...)よりも遅いように見えますが、私にとって奇妙なのは、foreach(...)がforループよりも速いように見えることです。

1
Puchacz