如何使用Linq对二维数组进行排序?

时间:2011-10-27 15:11:39

标签: c# linq

我有一个二维数组字符串

string [] [] myArray;

我希望按其中一个列对其进行排序。

所以数据可能是

{ "Apple", "2", "Bob" },
{ "Banana", "1", "Fred" }

我希望按任意列对其进行排序 - 我会有一个索引。

理想情况下,我想做myArray.Sort(1);

之类的事情

我知道我可能不得不使用自定义比较器。我认为这是一个有趣的学习机会。有人可以提供一些建议吗?

3 个答案:

答案 0 :(得分:5)

var myOrderedRows = myArray.OrderBy(row => row[columnIndex]);

答案 1 :(得分:2)

Array.Sort(myArray, (p, q) => p[0].CompareTo(q[0]));

这会将数组排序到位(所以最后myArray将被排序)。相比之下,LINQ OrderBy会创建一个新的有序枚举,然后您可以转换为ToArray

答案 2 :(得分:1)

你可以这样做......

IEnumerable<T> AsEnumerable(this T[,] arr) {
  for(int i = 0; i < arr.GetLength(0); i++)
    for(int j = 0; j < arr.GetLength(1); j++)
      yield return arr[i, j];
}

然后写例如:

int[,] data = // get data somwhere
// After 'AsEnumerable' you can use all standard LINQ operations
var res = data.AsEnumerable().OrderBy(n => n).Reverse();