Leer en inglés

Compartir a través de


Enumerable.Take Método

Definición

Sobrecargas

Take<TSource>(IEnumerable<TSource>, Int32)

Devuelve un número especificado de elementos contiguos desde el principio de una secuencia.

Take<TSource>(IEnumerable<TSource>, Range)

Devuelve un intervalo especificado de elementos contiguos de una secuencia.

Take<TSource>(IEnumerable<TSource>, Int32)

Source:
Take.cs
Source:
Take.cs
Source:
Take.cs

Devuelve un número especificado de elementos contiguos desde el principio de una secuencia.

C#
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, int count);

Parámetros de tipo

TSource

Tipo de los elementos de source.

Parámetros

source
IEnumerable<TSource>

Secuencia cuyos elementos se van a devolver.

count
Int32

Número de elementos que se van a devolver.

Devoluciones

IEnumerable<TSource>

IEnumerable<T> que contiene el número especificado de elementos desde el principio de la secuencia de entrada.

Excepciones

source es null.

Ejemplos

En el ejemplo de código siguiente se muestra cómo usar Take para devolver elementos desde el principio de una secuencia.

C#
int[] grades = { 59, 82, 70, 56, 92, 98, 85 };

IEnumerable<int> topThreeGrades =
    grades.OrderByDescending(grade => grade).Take(3);

Console.WriteLine("The top three grades are:");
foreach (int grade in topThreeGrades)
{
    Console.WriteLine(grade);
}
/*
 This code produces the following output:

 The top three grades are:
 98
 92
 85
*/

Comentarios

Este método se implementa mediante la ejecución diferida. El valor devuelto inmediato es un objeto que almacena toda la información necesaria para realizar la acción. La consulta representada por este método no se ejecuta hasta que el objeto se enumera llamando directamente a su GetEnumerator método o mediante foreach en C# o For Each en Visual Basic.

Take source enumera y produce elementos hasta count que se han producido elementos o source no contiene más elementos. Si count supera el número de elementos de source, se devuelven todos los elementos de source .

Si count es menor o igual que cero, source no se enumera y se devuelve un vacío IEnumerable<T> .

Los Take métodos y Skip son complementos funcionales. Dada una secuencia coll de colección y un entero n, concatenando los resultados de coll.Take(n) y coll.Skip(n) produce la misma secuencia que coll.

En la sintaxis de la expresión de consulta de Visual Basic, una Take cláusula se traduce en una invocación de Take.

Consulte también

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Take<TSource>(IEnumerable<TSource>, Range)

Source:
Take.cs
Source:
Take.cs
Source:
Take.cs

Devuelve un intervalo especificado de elementos contiguos de una secuencia.

C#
public static System.Collections.Generic.IEnumerable<TSource> Take<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Range range);

Parámetros de tipo

TSource

Tipo de los elementos de source.

Parámetros

source
IEnumerable<TSource>

Secuencia cuyos elementos se van a devolver.

range
Range

Intervalo de elementos que se van a devolver, que tiene índices iniciales y finales desde el principio o el final de la secuencia.

Devoluciones

IEnumerable<TSource>

que IEnumerable<T> contiene el intervalo especificado de elementos de la source secuencia.

Excepciones

source es null.

Comentarios

Este método se implementa mediante la ejecución diferida. El valor devuelto inmediato es un objeto que almacena toda la información necesaria para realizar la acción. La consulta representada por este método no se ejecuta hasta que el objeto se enumera llamando directamente a su GetEnumerator método o mediante foreach en C# o For Each en Visual Basic.

Take source enumera y produce elementos cuyos índices pertenecen al especificadorange.

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET 6, 7, 8, 9