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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...