Seq.Take <'T>. Função (F#)

Retorna os elementos da seqüência de até uma contagem especificada.

Caminho do namespace/módulo: Microsoft.FSharp.Collections.seq

Assembly: FSharp.Core (em FSharp.Core.dll)

// Signature:
Seq.take : int -> seq<'T> -> seq<'T>

// Usage:
Seq.take count source

Parâmetros

  • count
    Tipo: int

    O número de itens para levar.

  • source
    Tipo: SEQ<'T>

    A seqüência de entrada.

Exceções

Exceção

Condição

ArgumentException

Lançada quando a seqüência de entrada está vazia.

ArgumentNullException

Lançada quando a seqüência de entrada é nula.

InvalidOperationException

Lançada quando a contagem de exceder o número de elementos na seqüência.

Valor de retorno

A seqüência de resultado.

Comentários

Seq.TRUNCATE retorna a mesma quantidade de itens a seqüência contém, em vez de gerar uma exceção.

Esta função é chamada de Take em módulos (assemblies) compilados. Se você estiver acessando a função de um idioma diferente, por exemplo, F# ou através de reflexão, use esse nome.

Exemplo

O exemplo a seguir demonstra o uso de Seq.take e contrasta o comportamento com Seq.truncate.

let mySeq = seq { for i in 1 .. 10 -> i*i }
let truncatedSeq = Seq.truncate 5 mySeq
let takenSeq = Seq.take 5 mySeq

let truncatedSeq2 = Seq.truncate 20 mySeq
let takenSeq2 = Seq.take 20 mySeq

let printSeq seq1 = Seq.iter (printf "%A ") seq1; printfn ""

// Up to this point, the sequences are not evaluated.
// The following code causes the sequences to be evaluated.
truncatedSeq |> printSeq
truncatedSeq2 |> printSeq
takenSeq |> printSeq
// The following line produces a run-time error (in printSeq):
takenSeq2 |> printSeq
  

Plataformas

O Windows 7, SP2 do Windows Vista, Windows XP SP3, Windows XP Professional x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2

Informações sobre versão

O tempo de execução F#

Compatível com: 2.0, 4.0

Silverlight

Compatível com: 3

Consulte também

Referência

Módulo de Collections.SEQ (F#)

Microsoft.FSharp.Collections Namespace (F#)