本文由机器翻译。若要查看英语原文,请勾选“英语”复选框。 也可将鼠标指针移到文本上,在弹出窗口中显示英语原文。
翻译
英语

Enumerable.Select<TSource, TResult> 方法 (IEnumerable<TSource>, Func<TSource, Int32, TResult>)

 

通过合并元素的索引投影到一个新窗体的序列的每个元素。

命名空间:   System.Linq
程序集:  System.Core(位于 System.Core.dll)

public static IEnumerable<TResult> Select<TSource, TResult>(
	this IEnumerable<TSource> source,
	Func<TSource, int, TResult> selector
)

参数

source
Type: System.Collections.Generic.IEnumerable<TSource>

一个值序列,要对该序列调用转换函数。

selector
Type: System.Func<TSource, Int32, TResult>

一个应用于每个源元素的转换函数;函数的第二个参数表示源元素的索引。

返回值

Type: System.Collections.Generic.IEnumerable<TResult>

IEnumerable<T> 其元素是调用转换函数的每个元素的结果 source

类型参数

TSource

中的元素的类型 source

TResult

返回的值的类型 selector

Exception Condition
ArgumentNullException

sourceselectornull

此方法实现通过使用延迟的执行。 最接近的返回值是指存储执行的操作所需的所有信息的对象。 此方法所表示的查询不执行之前调用枚举的对象及其 GetEnumerator 方法直接或通过使用 foreach 中 Visual C# 或 For Each 中 Visual Basic。

第一个参数 selector 表示要处理的元素。 第二个参数 selector 表示源序列中该元素的从零开始索引。 如果元素顺序已知并且想要执行的特定索引处的元素为例,这会很有用。 它也可如果想要检索的一个或多个元素的索引。

此投影方法需要转换函数, selector, ,以生成一个值,为源序列中每个值 source 如果 selector 返回一个值,本身为一个集合,它负责的使用者手动遍历子序列。 在这种情况下,可能是你的查询以返回单个值的合并的序列中的显示效果会更好。 若要实现此目的,请使用 SelectMany<TSource, TResult> 方法而不是 Select<TSource, TResult> 尽管 SelectMany 工作原理类似于 Select, ,它不同之处在于转换函数返回一个集合,然后通过扩展 SelectMany 它返回的状态之前。

下面的代码示例演示如何使用 Select<TSource, TResult>(IEnumerable<TSource>, Func<TSource, Int32, TResult>) 对一系列值进行投影,并使用每个元素的索引。

string[] fruits = { "apple", "banana", "mango", "orange", 
                      "passionfruit", "grape" };

var query =
    fruits.Select((fruit, index) =>
                      new { index, str = fruit.Substring(0, index) });

foreach (var obj in query)
{
    Console.WriteLine("{0}", obj);
}

/*
 This code produces the following output:

 {index=0, str=}
 {index=1, str=b}
 {index=2, str=ma}
 {index=3, str=ora}
 {index=4, str=pass}
 {index=5, str=grape}
*/

通用 Windows 平台
自 8 起可用
.NET Framework
自 3.5 起可用
可移植类库
可移植 .NET 平台 中受支持
Silverlight
自 2.0 起可用
Windows Phone Silverlight
自 7.0 起可用
Windows Phone
自 8.1 起可用
返回页首
显示: