Seq.distinctBy < T','Key > Função (F#)
Retorna uma seqüência que contém entradas não duplicadas, de acordo com as comparações de hash e de igualdade genéricas nas chaves retornadas pela função de geração de chave fornecida. Se um elemento ocorre várias vezes na seqüência de ocorrências posteriores serão descartadas.
Caminho do namespace/módulo: Microsoft.FSharp.Collections.seq
Assembly: FSharp.Core (em FSharp.Core.dll)
// Signature:
Seq.distinctBy : ('T -> 'Key) -> seq<'T> -> seq<'T> (requires equality)
// Usage:
Seq.distinctBy projection source
Parâmetros
projection
Tipo: 'T -> 'KeyUma função que transforma os itens de seqüência em chaves comparáveis.
source
Tipo: SEQ<'T>A seqüência de entrada.
Exceções
Exceção |
Condição |
---|---|
Lançada quando a seqüência de entrada é nula. |
Valor de retorno
A seqüência de resultado.
Comentários
Esta função é chamada de DistinctBy 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.distinctBy para manter somente os elementos em uma seqüência que têm um valor absoluto de distinto. O primeiro elemento com um determinado resultado é mantido na nova seqüência, para que os números positivos de 1 a 5 são descartados na seqüência da -5 a + 10.
let inputSequence = { -5 .. 10 }
let printSeq seq1 = Seq.iter (printf "%A ") seq1; printfn ""
printfn "Original sequence: "
printSeq inputSequence
printfn "\nSequence with distinct absolute values: "
let seqDistinctAbsoluteValue = Seq.distinctBy (fun elem -> abs elem) inputSequence
seqDistinctAbsoluteValue |> 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