Функция Seq.distinctBy<'T,'Key> (F#)
Возвращает последовательность, которая не содержит дублирующихся записей в соответствии с универсальным хэшем и сравнениями ключей на равенство, возвращенными указанной функцией создания ключей. Если элемент встречается в последовательности несколько раз, последующие вхождения удаляются.
Пространство имен/путь к модулю: Microsoft.FSharp.Collections.Seq
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
Seq.distinctBy : ('T -> 'Key) -> seq<'T> -> seq<'T> (requires equality)
// Usage:
Seq.distinctBy projection source
Параметры
projection
Тип: 'T -> 'KeyФункция, преобразующая элементы последовательности в сравниваемые ключи.
source
Тип: seq<'T>Входная последовательность.
Исключения
Исключение |
Атрибут Condition |
---|---|
Создается при указании в качестве входной последовательности значения NULL. |
Возвращаемое значение
Результирующая последовательность.
Заметки
В скомпилированных сборках имя этой функции — DistinctBy. При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.
Пример
В следующем примере показано использование Seq.distinctBy чтобы сохранить только те элементы в последовательности, которые имеют определенные абсолютное значение. Первый элемент с данныс результатом сохраняется в новой последовательности, поэтому положительные числа от 1 до 5 понижаются в последовательности от -5 до + 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
Платформы
Windows 7, Windows Vista с пакетом обновления 2 (SP2), Windows XP с пакетом обновления 3 (SP3), Windows XP x64 с пакетом обновления 2 (SP2), Windows Server 2008 R2, Windows Server 2008 с пакетом обновления 2 (SP2), Windows Server 2003 с пакетом обновления 2 (SP2)
Сведения о версии
Среда выполнения F#
Поддерживается в версиях 2.0, 4.0
Silverlight
Поддерживается в версии 3