我需要对数据表进行排序,但按列排序有所不同。
场景 #1,DataTable1 应按“Column1”排序。
场景 #2,DataTable2 应按“Column1、Column2”排序。
下面是我为此目的创建辅助函数的第一次尝试。这工作正常。
Private Sub SortDataTable(ByRef dataTable As DataTable, ByVal sortColumnNames As List(Of String))
'Validation (not shown here)
Dim sortOrder = String.Join(", ", sortColumnNames)
dataTable.DefaultView.Sort = sortOrder
dataTable = dataTable.DefaultView.Table
End Sub
我尝试在 LINQ 中实现此功能,但是,我不知道如何将多个按列排序传递给 lambda 函数。正在进行的代码如下所示。
Private Sub SortDataTable(ByRef dataTable As DataTable, ByVal sortColumnNames As List(Of String))
'Validation (not shown here)
dataTable.AsEnumerable().OrderBy(Function (row) row(sortColumnNames(0))).ThenBy(...)
End Sub
我应该如何将多个按列排序传递给 OrderBy/ThenBy 扩展方法?
最佳答案
类似的事情:
Private Function SortDataTable(table As DataTable, ParamArray columns As String()) As DataTable
If columns.Length = 0 Then
Return table
End If
firstColumn = columns.First()
Dim result = table.AsEnumerable().OrderBy(Function(r) r(firstColumn))
For Each columnName As var In columns.Skip(1)
result = result.ThenBy(Function(r) r(columnName))
Next
Return result.AsDataView().ToTable()
End Function
从此 C# 代码转换而来(我用 C# 编写了此代码,然后使用 http://www.developerfusion.com/tools/convert/csharp-to-vb/ ):
DataTable SortDataTable(DataTable table, params string[] columns)
{
if (columns.Length == 0)
{
return table;
}
firstColumn = columns.First();
var result = table.AsEnumerable().OrderBy(r => r[firstColumn]);
foreach (var columnName in columns.Skip(1))
{
result = result.ThenBy(r => r[columnName]);
}
return result.AsDataView().ToTable();
}
PS:没有测试过。但这非常简单,所以应该没有问题。
关于vb.net - 当按列排序可能不同时,使用 LINQ 对 DataTable 进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16691900/