问题描述
使用 DataGrid,我显示了一个包含在运行时生成的内容的 DataTable。因此我不能使用预定义的列。每行包含一个名称作为其第一个元素,然后包含可变数量的数据,这些数据通常是数字,但也可能是 null
或字符串 "Invalid"
。
目前所有数据都被解释为字符串,这会导致对列进行排序导致按字母顺序而不是数字的问题,例如“0,1,12,20,3”而不是“0,3,20”。我试图通过从 IComparable<T>
继承所有显示的数据(DataGrid 忽略它),或通过覆盖 DataGrid 的 OnSorting()
方法(我只找到假设我使用 ListCollectionViews 的来源)来解决这个问题,而不是数据表)。
有谁知道如何在绑定到运行时生成的 DataTable 的 DataGrid 上实现自定义排序行为?
解决方法
我会使用 DataTable 而不是篡改 DataGrid。
如果不能对 DataTable 的源做任何事情,您可以使用 DataView 来获取 DataTable 的排序视图(请参阅 DataView.Sort)。
将 DataView 绑定到 DataGrid。
添加额外的列并使用 DataColumn.Expression 将字符串值转换为数值并处理空值和无效值。
请参阅此处的示例:
https://docs.microsoft.com/en-us/dotnet/api/system.data.datacolumn.expression?view=netframework-4.8