Seq.countBy<'T,'Key> 関数 (F#)
シーケンスの各要素にキー生成関数を適用し、固有のキーを生成するシーケンスと、元のシーケンスでの要素の数を返します。
名前空間/モジュール パス: Microsoft.FSharp.Collections.Seq
アセンブリ: FSharp.Core (FSharp.Core.dll 内)
// Signature: Seq.countBy : ('T -> 'Key) -> seq<'T> -> seq<'Key * int> (requires equality) // Usage: Seq.countBy projection source
パラメーター
projection
型: 'T -> 'Key入力シーケンスの各項目を、他と比較するキーに変換する関数。
source
型: seq<'T>入力シーケンス。
例外
例外 |
状態 |
---|---|
入力シーケンスが Null の場合にスローされます。 |
戻り値
一意のキーのシーケンスと、元のシーケンスでの要素の数。
解説
この関数は、初期シーケンスを反復すると即時に初期シーケンス全体を走査するシーケンスを返すことに注意してください。 このため、この関数を大きなシーケンスや無限シーケンスには使用しないでください。 この関数では、元のシーケンスの順序を想定しません。
この関数は、コンパイルされたアセンブリでは CountBy という名前です。 F# 以外の言語から、またはリフレクションを使用してこの関数にアクセスする場合は、この名前を使用します。
使用例
Seq.countBy を使用してシーケンスの要素の数が偶数と奇数のいずれであるかを判別する例を次に示します。
let mySeq1 = seq { 1.. 100 }
let printSeq seq1 = Seq.iter (printf "%A ") seq1; printfn ""
let seqResult = Seq.countBy (fun elem ->
if (elem % 2 = 0) then 0 else 1) mySeq1
printSeq seqResult
プラットフォーム
Windows 8、Windows 7、Windows Server 2012、Windows Server 2008 R2
バージョン情報
F# コア ライブラリのバージョン
2.0、4.0、Portable でサポート