有没有一种简单的内置方法来获取一个有序的IEnumerable
s 列表并返回一个IEnumerable
,它按顺序产生第一个中的所有元素,然后是第二个,依此类推。
我当然可以自己写,但我想知道在我做之前是否已经有办法完成这个看似有用的任务。
有没有一种简单的内置方法来获取一个有序的IEnumerable
s 列表并返回一个IEnumerable
,它按顺序产生第一个中的所有元素,然后是第二个,依此类推。
我当然可以自己写,但我想知道在我做之前是否已经有办法完成这个看似有用的任务。
试试 SelectMany。
IEnumerable<int> Collapse(IEnumerable<IEnumerable<int>> e){
return e.SelectMany(x => x );
}
此函数的目的是将一组 IEnumerable<IEnumerable<T>> 展平为一个 IEnumerable<T>。返回的数据将保留原始顺序。
除了 JaredPar 的(正确)答案之外 - 还有查询语法:
var all = from inner in outer
from item in inner
select item;
除了(正确的)基于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);