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>

    输入序列。

异常

异常

Condition

ArgumentNullException

在输入序列为 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 7、Windows Vista SP2、Windows XP SP3、Windows XP x64 SP2、Windows Server 2008 R2、Windows Server 2008 SP2、Windows Server 2003 SP2

版本信息

F# 运行时

受以下版本支持:2.0、4.0

Silverlight

受以下版本支持:3

请参见

参考

Collections.Seq 模块 (F#)

Microsoft.FSharp.Collections 命名空间 (F#)