19

有没有一种简单的内置方法来获取一个有序的IEnumerables 列表并返回一个IEnumerable,它按顺序产生第一个中的所有元素,然后是第二个,依此类推。

我当然可以自己写,但我想知道在我做之前是否已经有办法完成这个看似有用的任务。

4

3 回答 3

24

试试 SelectMany。

IEnumerable<int> Collapse(IEnumerable<IEnumerable<int>> e){
 return e.SelectMany(x => x );
}

此函数的目的是将一组 IEnumerable<IEnumerable<T>> 展平为一个 IEnumerable<T>。返回的数据将保留原始顺序。

于 2009-02-08T18:22:12.130 回答
15

除了 JaredPar 的(正确)答案之外 - 还有查询语法:

var all = from inner in outer
          from item in inner
          select item;
于 2009-02-08T18:24:26.553 回答
13

除了(正确的)基于LINQ的答案......

如果您不想使用 LINQ,可以使用 yield 发明一个 ChainedEnumerable 类:

public class ChainedEnumerable<T> : IEnumerable<T>
{
    private readonly IEnumerable<T>[] _inners;

    public ChainedEnumerable(params IEnumerable<T>[] inners)
    {
        _inners = inners;
    }

    public IEnumerator<T> GetEnumerator()
    {
        foreach (IEnumerable<T> inner in _inners)
        {
            foreach (T t in inner)
            {
                yield return t;
            }
        }
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        return GetEnumerator();
    }
}

像这样使用它:

List<string> a = new List<string> { "A1", "A2", "A3" };
List<string> b = new List<string> { "B1", "B2", "B3" };
ChainedEnumerable<string> chainedEnumerable =
    new ChainedEnumerable<string>(a, b);
foreach (string s in chainedEnumerable)
    Console.WriteLine(s);
于 2009-02-08T18:34:54.927 回答