WPF DataGrid - 使用 DataTable 作为 ItemsSource 的自定义排序

问题描述

使用 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