Enumerable.Take 方法

定義

多載

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

從序列開頭傳回指定的連續項目數目。

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

傳回序列中連續專案的指定範圍。

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

來源:
Take.cs
來源:
Take.cs
來源:
Take.cs

從序列開頭傳回指定的連續項目數目。

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

類型參數

TSource

source 項目的類型。

參數

source
IEnumerable<TSource>

傳回項目的序列。

count
Int32

要傳回的項目數目。

傳回

IEnumerable<TSource>

IEnumerable<T>,其中包含輸入序列開頭處指定的項目數目。

例外狀況

sourcenull

範例

下列程式代碼範例示範如何使用 Take 從序列開頭傳回專案。

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

備註

此方法是使用延後執行來實作。 立即傳回值是物件,可儲存執行動作所需的所有資訊。 除非直接在 GetEnumerator C# 或 Visual Basic 中使用 foreach 來列舉對象,否則 For Each 不會執行這個方法所表示的查詢。

Take source列舉併產生專案,直到count產生專案或source不包含更多項目為止。 如果 count 超過中的 source項目數目,則會傳回 的所有 元素 source

如果 count 小於或等於零, source 則不會列舉,而且會傳回空 IEnumerable<T> 的 。

TakeSkip 方法是功能性補碼。 給定集合序列coll和整數n,串連 和 coll.Skip(n) 的結果coll.Take(n)會產生與 coll相同的序列。

在 Visual Basic 查詢表達式語法中 Take ,子句會轉譯為的 Take調用。

另請參閱

適用於

.NET 9 及其他版本
產品 版本
.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)

來源:
Take.cs
來源:
Take.cs
來源:
Take.cs

傳回序列中連續專案的指定範圍。

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

類型參數

TSource

source 項目的類型。

參數

source
IEnumerable<TSource>

傳回項目的序列。

range
Range

要傳回的專案範圍,其具有序列開頭或結尾的開始和結束索引。

傳回

IEnumerable<TSource>

IEnumerable<T>,包含序列中source指定之項目範圍。

例外狀況

sourcenull

備註

此方法是使用延後執行來實作。 立即傳回值是物件,可儲存執行動作所需的所有資訊。 除非直接在 GetEnumerator C# 或 Visual Basic 中使用 foreach 來列舉對象,否則 For Each 不會執行這個方法所表示的查詢。

Take source列舉併產生索引屬於指定 range之的專案。

適用於

.NET 9 及其他版本
產品 版本
.NET 6, 7, 8, 9