【C#とLINQ】Aggregateメソッドを使ってデータの集計をする方法
C#にはLINQという素晴らしい機能があり、LINQを使用することで配列、リスト、XMLなどのデータソースを「共通の構文で」「簡潔」に処理できます。今回はLINQの Aggregateメソッドの使い方を解説します。
- プログラマー
- LINQのSumやMaxメソッドは、名前からして用途が分かりやすいですが、 Aggregate はどんな時に使用しますか?
- プロジェクト
リーダー - Aggregateは色々な用途の集計で使えます。一言では言い表せないので、これから1ずつ見ていきましょう。
LINQのAggregateメソッドでできること
C#の Aggregate メソッドを使用すると、汎用的な集計ができます。 Aggregateメソッドは、他のプログラム言語では「畳み込み(fold)」などとも呼ばれます。
Aggregateメソッドの処理の流れは、以下のようになっています。
- 配列などのデータソースから1件ずつ要素を取り出す
- 引数で渡した関数を実行し、累積値を更新する
- 最終的な累積値を、 Aggregateメソッドの戻り値とする
上の解説だけではピンとこないと思いますが、具体的な例では、Aggregateメソッドを使用すると、数値の合計値や最大値、最小値を求める集計処理が行えます。
Aggregateメソッドを使用した集計 (C#サンプルコード)
AggregateメソッドはLINQのSum(合計)やMax(最大値)など、機能が明確で使い方が簡単なメソッドと比べて少し使い方が難しいメソッドです。サンプルコードを見ながら学んでいきましょう。
次のサンプルコードは、数値の配列の合計値を Aggregate メソッドを使って求めるコードです。
1
2
3
4
5
6
7
8
9
|
using System.Linq;
public class SampleClass {
public static void Main(){
int[] source = { 10, 20, 40, 30 };
int ans = source.Aggregate((sum, n) => sum + n);
System.Console.WriteLine("合計値:" + ans);
}
}
|
実行結果
Aggregateメソッドの引数の変化を確認する
サンプルコードの実行結果を見ると、正しく数値配列の合計値が求めらていますが、なぜAggregateメソッドに指定する関数に、「n + sum」と書くだけで、合計値が求められるか不思議に思う方もいるでしょう。
Aggregateメソッドを理解する為には、メソッドに指定する関数【(n, sum) => n + sum)】の引数が、どのように変化するのかを知ると、理解が大きく進みます。
以下は、Aggregateメソッドに指定した関数の、引数の流れをまとめた表です。
呼出回数 | sum | n | 戻り値 |
1回目 | 10 | 20 | 30 |
2回目 | 30 | 40 | 70 |
3回目 | 70 | 30 | 100 |
1回目の呼び出しは、sumに配列1件目の要素、nに2件目の要素が設定されています。
2回目以降の呼び出しでは、sumに前の呼び出しの戻り値、nには配列の次の要素が設定されています。
このように、C#のAggregateメソッドは累積値を加算しながら、最終的に合計値を求めています。
- プログラマー
- 実際に引数の流れを見るとAggregateメソッドが理解できました。
- プロジェクト
リーダー - Aggregateは、単に合計値を求めるだけでなく、もっと複雑な集計処理にも使えるから是非挑戦してみてくださいね。
LINQのAggregateをマスターして複雑な集計処理をシンプルに
LINQのAggregateメソッドの使い方を、C#のサンプルコードと共に解説してきました。今回は、数値配列の合計値を求めるシンプルな集計処理でしたが、Aggregateメソッドを使用すると、複雑な集計処理もシンプルなコードで書けるようになります。
FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
株式会社オープンアップシステムはこんな会社です
秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
数多くのエンジニアが集まります。
-
スマホアプリから業務系システムまで
スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。
-
充実した研修制度
毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。
-
資格取得を応援
スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。
-
東証プライム上場企業グループ
オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
株式会社オープンアップシステムに興味を持った方へ
株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。
C#新着案件New Job
-
システム開発/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(新宿駅) -
システム開発/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(新宿駅) -
デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円神奈川県横浜市(桜木町駅) -
デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円神奈川県横浜市(桜木町駅) -
基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(西新宿駅) -
基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(西新宿駅)