Enumerable.Take Metodo

Definizione

Overload

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

Restituisce un numero specificato di elementi contigui dall'inizio di una sequenza.

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

Restituisce un intervallo specificato di elementi contigui da una sequenza.

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

Origine:
Take.cs
Origine:
Take.cs
Origine:
Take.cs

Restituisce un numero specificato di elementi contigui dall'inizio di una sequenza.

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

Parametri di tipo

TSource

Tipo degli elementi di source.

Parametri

source
IEnumerable<TSource>

Sequenza dalla quale vengono restituiti gli elementi.

count
Int32

Numero di elementi da restituire.

Restituisce

IEnumerable<TSource>

Oggetto IEnumerable<T> che contiene il numero specificato di elementi, dall'inizio della sequenza di input.

Eccezioni

source è null.

Esempio

Nell'esempio di codice seguente viene illustrato come usare Take per restituire elementi dall'inizio di una sequenza.

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
*/

Commenti

Questo metodo viene implementato usando l'esecuzione posticipata. Il valore restituito immediato è un oggetto che archivia tutte le informazioni necessarie per eseguire l'azione. La query rappresentata da questo metodo non viene eseguita finché l'oggetto non viene enumerato chiamando il GetEnumerator relativo metodo direttamente o usando foreach in C# o For Each in Visual Basic.

Take enumera e restituisce source elementi fino a quando count gli elementi non sono stati restituiti o source non contengono più elementi. Se count supera il numero di elementi in source, vengono restituiti tutti gli elementi di source .

Se count è minore o uguale a zero, source non viene enumerato e viene restituito un vuoto IEnumerable<T> .

I Take metodi e Skip sono complementi funzionali. Dato una sequenza di raccolta e un numero intero , concatenando i risultati di e coll.Skip(n) restituisce la stessa sequenza coll di coll.Take(n)coll.n

Nella sintassi dell'espressione di query di Visual Basic, una Take clausola si traduce in una chiamata di Take.

Vedi anche

Si applica a

.NET 9 e altre versioni
Prodotto Versioni
.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)

Origine:
Take.cs
Origine:
Take.cs
Origine:
Take.cs

Restituisce un intervallo specificato di elementi contigui da una sequenza.

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

Parametri di tipo

TSource

Tipo degli elementi di source.

Parametri

source
IEnumerable<TSource>

Sequenza dalla quale vengono restituiti gli elementi.

range
Range

Intervallo di elementi da restituire, con indici iniziali e finali dall'inizio o dalla fine della sequenza.

Restituisce

IEnumerable<TSource>

Oggetto IEnumerable<T> contenente l'intervallo specificato di elementi dalla source sequenza.

Eccezioni

source è null.

Commenti

Questo metodo viene implementato usando l'esecuzione posticipata. Il valore restituito immediato è un oggetto che archivia tutte le informazioni necessarie per eseguire l'azione. La query rappresentata da questo metodo non viene eseguita finché l'oggetto non viene enumerato chiamando il GetEnumerator relativo metodo direttamente o usando foreach in C# o For Each in Visual Basic.

Take enumera e restituisce source elementi i cui indici appartengono all'oggetto specificato range.

Si applica a

.NET 9 e altre versioni
Prodotto Versioni
.NET 6, 7, 8, 9