导出 (0) 打印
全部展开
此文章由机器翻译。 将光标移到文章的句子上,以查看原文。 更多信息。
译文
原文

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

将序列的每个元素投影到 IEnumerable<T>,并将结果序列合并为一个序列。 每个源元素的索引用于该元素的投影表。

命名空间:  System.Linq
程序集:  System.Core(在 System.Core.dll 中)

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

类型参数

TSource

source 中的元素的类型。

TResult

selector 返回的序列元素的类型。

参数

source
类型:System.Collections.Generic.IEnumerable<TSource>
一个要投影的值序列。
selector
类型:System.Func<TSource, Int32, IEnumerable<TResult>>
一个应用于每个源元素的转换函数;函数的第二个参数表示源元素的索引。

返回值

类型:System.Collections.Generic.IEnumerable<TResult>
一个 IEnumerable<T>,其元素是对输入序列的每个元素调用一对多转换函数的结果。

使用说明

在 Visual Basic 和 C# 中,可以在 IEnumerable<TSource> 类型的任何对象上将此方法作为实例方法来调用。当使用实例方法语法调用此方法时,请省略第一个参数。有关详细信息,请参阅扩展方法 (Visual Basic)扩展方法(C# 编程指南)

异常条件
ArgumentNullException

sourceselectornull

此方法通过使用延迟执行实现。 即时返回值为一个对象,该对象存储执行操作所需的所有信息。 只有通过直接调用对象的 GetEnumerator 方法或使用 Visual C# 中的 foreach(或 Visual Basic 中的 For Each)来枚举该对象时,才执行此方法表示的查询。

SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, Int32, IEnumerable<TResult>>) 方法枚举输入序列,使用转换函数将每个元素映射到 IEnumerable<T>,然后枚举并生成每个这种 IEnumerable<T> 对象的元素。 也就是说,对于 source 的每个元素,selector 被调用,返回一个值的序列。 然后 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, Int32, IEnumerable<TResult>>) 将集合的此二维集合合并为一维 IEnumerable<T> 并将其返回。 例如,如果查询使用 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, Int32, IEnumerable<TResult>>) 获取数据库中每个使用方的顺序(类型为 Order),结果属于 C# 中的 IEnumerable<Order> 类型或 Visual Basic 中的 IEnumerable(Of Order) 类型。 而如果查询使用了 Select 获取顺序,则未合并顺序集合的集合,并且结果属于 C# 中的 IEnumerable<List<Order>> 类型或 Visual Basic 中的 IEnumerable(Of List(Of Order)) 类型。

selector 的第一个参数表示要处理的元素。 selector 的第二个参数表示源序列中的该元素的从零开始的索引。 如果已知元素的排列顺序,这将很有用,例如,您想要处理位于特定索引处的元素。 如果您想要检索一个或更多元素的索引,这也很有用。

下面的代码示例演示如何使用 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, Int32, IEnumerable<TResult>>) 在数组上执行一对多的投影并使用每个外部元素的索引。


            class PetOwner
            {
                public string Name { get; set; }
                public List<string> Pets { get; set; }
            }

            public static void SelectManyEx2()
            {
                PetOwner[] petOwners = 
                    { new PetOwner { Name="Higa, Sidney", 
                          Pets = new List<string>{ "Scruffy", "Sam" } },
                      new PetOwner { Name="Ashkenazi, Ronen", 
                          Pets = new List<string>{ "Walker", "Sugar" } },
                      new PetOwner { Name="Price, Vernette", 
                          Pets = new List<string>{ "Scratches", "Diesel" } },
                      new PetOwner { Name="Hines, Patrick", 
                          Pets = new List<string>{ "Dusty" } } };

                // Project the items in the array by appending the index 
                // of each PetOwner to each pet's name in that petOwner's 
                // array of pets.
                IEnumerable<string> query =
                    petOwners.SelectMany((petOwner, index) =>
                                             petOwner.Pets.Select(pet => index + pet));

                foreach (string pet in query)
                {
                    Console.WriteLine(pet);
                }
            }

            // This code produces the following output:
            //
            // 0Scruffy
            // 0Sam
            // 1Walker
            // 1Sugar
            // 2Scratches
            // 2Diesel
            // 3Dusty



.NET Framework

受以下版本支持:4.5.2、4.5.1、4.5、4、3.5

.NET Framework Client Profile

受以下版本支持:4、3.5 SP1

可移植类库

受以下版本支持:可移植类库

适用于 Windows 应用商店应用的 .NET

受以下版本支持:Windows 8

适用于 Windows Phone 应用的 .NET

受以下版本支持:Windows Phone 8、Silverlight 8.1

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008(不支持服务器核心角色), Windows Server 2008 R2(支持带 SP1 或更高版本的服务器核心角色;不支持 Itanium)

.NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参阅.NET Framework 系统要求

社区附加资源

添加
显示:
© 2015 Microsoft