-3

请在以下方面帮助我...我有两个列表对象,如下所示:

list1:
ID  col1
--------
1   A
1   B
1   C

list2:
ID  col2
--------
1   D
1   E 
1   F

Now I want:
ID  col1  col2
---------------
1    A     D
1    B     E
1    C     F

所以基本上column1然后是list1中的column 2,然后是list 2中的column 3。column1是常见的。请注意,行数可能并不总是相同的。在这种情况下,它将为空。

我真的很需要 Linq 中的这个解决方案。谢谢。

4

2 回答 2

3
List<Class> list1 = new List<Class>();
List<Class> list2 = new List<Class>();

// Add classes to lists...

list1.AddRange(list2);

// Order merged list...

list1.OrderByDescending(o => o.col1).ThenBy(o => o.col2);

试图理解...

Dictionary<Int32, Class[]> dictionary = new Dictionary<Int32, Class[]>();

list2.Reverse();

for (Int32 i = 0; i < list1.Count; ++i)
    dictionary[i] = new Class[2] { list1[i], list2[i] };
于 2013-01-15T17:09:05.507 回答
1

我真的不明白为什么很难弄清楚这个问题,他只想将两个数组合二为一(我仍然不知道为什么在网络上你只能找到 Concat、AddRange 或 Union。错误的答案这个问题):

我用 Zip 解决它:

       var result = list1.Zip(list2,(first,second)=>new  {entrada=first,salida=second});

现在你可以做这样的事情:

       var union=result.Select(x=> new {x.entrada, x.salida, horas = int.Parse((DateTime.Parse(x.salida).Subtract(DateTime.Parse(x.entrada))).Hours.ToString()) });
于 2017-01-07T08:40:59.673 回答