4

我有一个多维列表:

    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);
}
4

4 回答 4

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);
}
于 2012-07-08T12:04:02.433 回答
2

如果要按顺序遍历这两个列表,可以使用IEnumerable<T>.Union(IEnumerable<T>)扩展方法

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);
}
于 2012-07-08T12:05:14.873 回答
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);
    }
}
于 2012-07-08T12:07:23.217 回答
-1

改用 LINQ:

foreach (var s in list.SelectMany(l => l)) { Console.WriteLine(s); }

于 2012-07-08T12:07:27.343 回答