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

我有一个2d的字符串数组

string [] [] myArray; 

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

所以数据可能是

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

我希望按任何列对它进行排序 – 我将有一个索引。

理想情况下,我想做像myArray.Sort(1);这样的事情myArray.Sort(1);

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

 var myOrderedRows = myArray.OrderBy(row => row[columnIndex]); 
 Array.Sort(myArray, (p, q) => p[0].CompareTo(q[0])); 

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

你可以这样做……

 IEnumerable 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();