Функция Seq.take<'T> (F#)
Возвращает элементы последовательности вплоть до указанного номера.
Пространство имен/путь к модулю: Microsoft.FSharp.Collections.Seq
Сборка: FSharp.Core (в FSharp.Core.dll)
// Signature:
Seq.take : int -> seq<'T> -> seq<'T>
// Usage:
Seq.take count source
Параметры
count
Тип: intЧисло элементов, которые нужно принять.
source
Тип: seq<'T>Входная последовательность.
Исключения
Исключение |
Атрибут Condition |
---|---|
Создается в случае пустой входной последовательности. |
|
Создается при указании в качестве входной последовательности значения NULL. |
|
Вызывается, если счетчик превышает число элементов в последовательности. |
Возвращаемое значение
Результирующая последовательность.
Заметки
Seq.truncate возвращает столько элементов, сколько содержит последовательность, вместо вызова исключения.
В скомпилированных сборках имя этой функции — Take.При обращении к функции из языка, отличного от F#, или посредством отражения следует использовать это имя.
Пример
В следующем примере демонстрируется использование функции Seq.take и ее поведение сравнивается с поведением функции 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
Платформы
Windows 8, Windows 7, Windows Server 2012, Windows 2008 Server R2
Сведения о версии
Основной версии библиотеки F#
Поддерживается в: 2.0, 4.0, портативное