我有一个多维列表:
List<string>[] list = new List<string>[2];
list[0] = new List<string>();
list[1] = new List<string>();
我按照以下方式迭代列表 - 但这只迭代一个列表:
foreach (String str in dbConnectObject.Select()[0])
{
Console.WriteLine(str);
}
虽然我希望能够做到这样的事情:
foreach (String str in dbConnectObject.Select()[0] & String str2 in dbConnectObject.Select()[1])
{
Console.WriteLine(str + str2);
}
答案 0 :(得分:6)
如果列表大小相同,您可以使用Enumerable.Zip
:
foreach (var p in dbConnectObject.Select()[0].Zip(dbConnectObject.Select()[1], (a,b) => new {First = a, Second = b})) {
Console.Writeline("{0} {1}", p.First, p.Second);
}
答案 1 :(得分:2)
如果您想要按顺序遍历这两个列表,可以使用IEnumerable<T>.Union(IEnumerable<T>)
extension method:
IEnumerable<string> union = list[0].Union(list[1]);
foreach(string str int union)
{
DoSomething(str);
}
如果您想要组合矩阵,可以加入列表:
var joined = from str1 in list[0]
from str2 in list[1]
select new { str1, str2};
foreach(var combination in joined)
{
//DoSomethingWith(combination.str1, combination.str2);
Console.WriteLine(str + str2);
}
答案 2 :(得分:0)
您可以尝试以下代码。如果尺寸不同,它也可以使用。
for (int i = 0; i < list[0].Count; i++)
{
var str0 = list[0][i];
Console.WriteLine(str0);
if (list[1].Count > i)
{
var str1 = list[1][i];
Console.WriteLine(str1);
}
}
答案 3 :(得分:-1)
改用LINQ:
foreach (var s in list.SelectMany(l => l))
{
Console.WriteLine(s);
}