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

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

 

一个序列的每个元素投影 IEnumerable<T> 并将合并为一个序列将结果序列。

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

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

参数

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

一个要投影的值序列。

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

应用于每个元素的转换函数。

返回值

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

IEnumerable<T> 其元素是一种一对多转换函数对输入序列中的每个元素调用的结果。

类型参数

TSource

中的元素的类型 source

TResult

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

Exception Condition
ArgumentNullException

sourceselectornull

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

SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TResult>>) 方法枚举的输入的序列中,使用转换函数映射到每个元素 IEnumerable<T>, ,然后枚举并生成的每个此类元素 IEnumerable<T> 对象。 也就是说,每个元素的 source, ,selector 调用并返回一个值序列。 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TResult>>) 然后将平展集合到一维此二维集合 IEnumerable<T> 并将其返回。 例如,如果查询使用 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TResult>>) 获取订单 (类型的 Order) 为数据库中每个客户,则结果是类型 IEnumerable<Order> 在 C# 或 IEnumerable(Of Order) 中 Visual Basic。 如果改为查询使用 Select<TSource, TResult> 若要获取订单,订单的组成的集合没有组合并且结果类型是 IEnumerable<List<Order>> 在 C# 或 IEnumerable(Of List(Of Order)) 中 Visual Basic。

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

下面的代码示例演示如何使用 SelectMany<TSource, TResult>(IEnumerable<TSource>, Func<TSource, IEnumerable<TResult>>) 若要在数组上执行的一对多投影。

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

public static void SelectManyEx1()
{
    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" } } };

    // Query using SelectMany().
    IEnumerable<string> query1 = petOwners.SelectMany(petOwner => petOwner.Pets);

    Console.WriteLine("Using SelectMany():");

    // Only one foreach loop is required to iterate 
    // through the results since it is a
    // one-dimensional collection.
    foreach (string pet in query1)
    {
        Console.WriteLine(pet);
    }

    // This code shows how to use Select() 
    // instead of SelectMany().
    IEnumerable<List<String>> query2 =
        petOwners.Select(petOwner => petOwner.Pets);

    Console.WriteLine("\nUsing Select():");

    // Notice that two foreach loops are required to 
    // iterate through the results
    // because the query returns a collection of arrays.
    foreach (List<String> petList in query2)
    {
        foreach (string pet in petList)
        {
            Console.WriteLine(pet);
        }
        Console.WriteLine();
    }
}

/*
 This code produces the following output:

 Using SelectMany():
 Scruffy
 Sam
 Walker
 Sugar
 Scratches
 Diesel

 Using Select():
 Scruffy
 Sam

 Walker
 Sugar

 Scratches
 Diesel
*/

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