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

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

 

一个序列的每个元素投影 IEnumerable<T>, 将平展为一个序列,将结果序列,其中调用结果选择器函数对每个元素。

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

public static IEnumerable<TResult> SelectMany<TSource, TCollection, TResult>(
	this IEnumerable<TSource> source,
	Func<TSource, IEnumerable<TCollection>> collectionSelector,
	Func<TSource, TCollection, TResult> resultSelector
)

参数

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

一个要投影的值序列。

collectionSelector
Type: System.Func<TSource, IEnumerable<TCollection>>

要应用于输入序列中的每个元素转换函数。

resultSelector
Type: System.Func<TSource, TCollection, TResult>

要应用于中间序列的每个元素的转换函数。

返回值

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

IEnumerable<T> 其元素是调用一种一对多转换函数的结果 collectionSelector 的每个元素 source 然后将每个这些序列元素和其相应的源元素映射到一个结果元素。

类型参数

TSource

中的元素的类型 source

TCollection

中间元素的类型由收集 collectionSelector

TResult

结果序列的元素的类型。

Exception Condition
ArgumentNullException

sourcecollectionSelectorresultSelectornull

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

SelectMany<TSource, TCollection, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TCollection>>, Func<TSource, TCollection, TResult>) 方法很有用,当您需要保留的元素时 source 范围内的调用之后发生的查询逻辑 SelectMany<TSource, TCollection, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TCollection>>, Func<TSource, TCollection, TResult>) 有关代码示例,请参见“示例”部分。 类型的对象之间是否存在双向关系 TSource 和类型的对象 TCollection, ,即,如果类型的对象 TCollection 提供一个属性来检索 TSource 对象生成,不需要的此重载 SelectMany<TSource, TCollection, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TCollection>>, Func<TSource, TCollection, TResult>) 相反,您可以使用 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TResult>>) 和向后定位到 TSource 对象传递 TCollection 对象。

在查询表达式语法中,每个 from 子句 (Visual C#) 或 From 子句 (Visual Basic) 在初始后一个将转换为的一个调用 SelectMany<TSource, TResult>

下面的代码示例演示如何使用 SelectMany<TSource, TCollection, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TCollection>>, Func<TSource, TCollection, TResult>) 若要在数组上执行的一对多投影并且使用结果选择器函数来保持范围内的最后一次调用到源序列中的每个相应元素 Select

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

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

    // Project the pet owner's name and the pet's name.
    var query =
        petOwners
        .SelectMany(petOwner => petOwner.Pets, (petOwner, petName) => new { petOwner, petName })
        .Where(ownerAndPet => ownerAndPet.petName.StartsWith("S"))
        .Select(ownerAndPet =>
                new
                {
                    Owner = ownerAndPet.petOwner.Name,
                    Pet = ownerAndPet.petName
                }
        );

    // Print the results.
    foreach (var obj in query)
    {
        Console.WriteLine(obj);
    }
}

// This code produces the following output:
//
// {Owner=Higa, Pet=Scruffy}
// {Owner=Higa, Pet=Sam}
// {Owner=Ashkenazi, Pet=Sugar}
// {Owner=Price, Pet=Scratches}

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