Seq.groupBy<'T,'Key> 関数 (F#)
シーケンスの各要素にキー生成関数を適用し、一意キーのシーケンスと各キーを持つすべての要素のシーケンスを生成します。
名前空間/モジュール パス: Microsoft.FSharp.Collections.Seq
アセンブリ: FSharp.Core (FSharp.Core.dll 内)
// Signature:
Seq.groupBy : ('T -> 'Key) -> seq<'T> -> seq<'Key * seq<'T>> (requires equality)
// Usage:
Seq.groupBy projection source
パラメーター
projection
型: 'T -> 'Keyシーケンスの要素をコンパイル可能なキーに変換する関数。
source
型: seq<'T>入力シーケンス。
戻り値
一意キーをそれぞれ含んだタプルのシーケンスと、キーに一致するすべての要素のシーケンス。
解説
この関数は、最初のシーケンスが反復処理されるとすぐに、そのシーケンス全体を走査するシーケンスを返します。そのため、この関数は大きいシーケンスまたは無限のシーケンスでは使用しないでください。この関数には、元のシーケンスの順序に関する想定はありません。
この関数は、コンパイルされたアセンブリでは GroupBy という名前です。F# 以外の言語から、またはリフレクションを使用してこの関数にアクセスする場合は、この名前を使用します。
使用例
Seq.groupBy を使用して、1 つのシーケンス内の奇数と偶数を 2 つの別々のシーケンスにグループ化する例を次に示します。
let sequence = seq { 1 .. 100 }
let printSeq seq1 = Seq.iter (printf "%A ") seq1; printfn ""
let sequences3 = Seq.groupBy (fun index ->
if (index % 2 = 0) then 0 else 1) sequence
sequences3 |> printSeq
プラットフォーム
Windows 8、Windows 7、Windows Server 2012 で Windows Server 2008 R2
バージョン情報
F# コア ライブラリのバージョン
サポート: ポータブル 2.0、4.0