自定义排序顺序 - DataGridView

Dan*_*son 2 c# datatable datagridview winforms

是否可以在 datagridview 中对此进行排序,而无需在 + 之后将数据填充为 3 个值。
数据类型是字符串,datagridview 列是文本。

10:10+01
10:10+100
10:10+110
10:10+10
Run Code Online (Sandbox Code Playgroud)

应该这样排序

 10:10+01
 10:10+10
 10:10+100
 10:10+110
Run Code Online (Sandbox Code Playgroud)

也许将排序模式更改为程序化可能会有所帮助?

任何输入将不胜感激

编辑:将数据复制到 dt 然后与数据视图绑定的示例。

DataTable dtTest = new DataTable();
dtTest.Columns.Add("Column1", typeof(string));
dtTest.Rows.Add("10:11+1");
dtTest.Rows.Add("10:11+101");
dtTest.Rows.Add("10:11+101");
dtTest.Rows.Add("10:11+2");
dtTest.Rows.Add("10:11+200");
dtTest.Rows.Add("10:10+1110");
DataView dvTest = new DataView(dtTest);
dataGridView1.DataSource = dvTest;
Run Code Online (Sandbox Code Playgroud)

示例排序顺序

10:10+1110
10:11+1
10:11+101
10:11+101
10:11+2
10:11+200
Run Code Online (Sandbox Code Playgroud)

TaW*_*TaW 6

自定义排序未绑定的 DataGridview

不确定您的数据,但从字面上看,这将完成未绑定 的工作DataGridView DGV

首先你需要连接一个SortCompare处理程序,可能像这样

 DGV.SortCompare += new DataGridViewSortCompareEventHandler(  this.DGV_SortCompare);
Run Code Online (Sandbox Code Playgroud)

如有必要,您可以在您的列上调用它(或让标题单击完成工作):

 DGV.Sort(DGV.Columns[yourColumn], ListSortDirection.Ascending);
Run Code Online (Sandbox Code Playgroud)

这是 SortCompare 事件代码。它使用简单的字符串操作通过用零填充最后一部分来创建可排序的版本。

 private void DGV_SortCompare(object sender, DataGridViewSortCompareEventArgs e)
 {
   string s1 = e.CellValue1.ToString().Substring(0, 6) + 
               e.CellValue1.ToString().Substring(6).PadLeft(5, '0');
   string s2 = e.CellValue2.ToString().Substring(0, 6) + 
               e.CellValue2.ToString().Substring(6).PadLeft(5, '0');
   e.SortResult = s1.CompareTo(s2);
   e.Handled = true;
 }
Run Code Online (Sandbox Code Playgroud)

MSDN 上对 DGV 排序的三种方法进行了全面的讨论- 显然,这是解决您问题的最简单方法。也相当灵活:您也可以使用该e.columnIndex参数为其他列创建单独的比较字符串。

如果其他列不需要特殊的排序代码,则应将此行插入到 的开头SortCompare

  if (e.Column.Index != yourColumn) return;
Run Code Online (Sandbox Code Playgroud)

自定义排序数据绑定 DataGridView

更新:由于您已将问题更改为DataBound DGV,因此对于这种情况,这里有一个类似的解决方案:

BindingSource BS = new BindingSource();

private void sortButton_Click(object sender, EventArgs e)
{
    DT.Columns.Add("TempSort");
    foreach (DataRow row in DT.Rows)
    {
        string val = row[yourcolumn].ToString();
        row["TempSort"] = val.ToString().Substring(0, 6) + 
                          val.ToString().Substring(6).PadLeft(5, '0');
    }
    BS.DataSource = DT;
    BS.Sort = "TempSort ASC";
    DT.Columns.Remove("TempSort");
    DGV.DataSource = BS;
}
Run Code Online (Sandbox Code Playgroud)

此解决方案假设您DataSource是一个DataTable DT,并将创建一个名为“TempSort”的临时列,并用准备好的数据值版本填充它;它将升序排序。

对于排序,我们使用BindingSource.

要动态控制右列(此处称为“ yourcolumn”)以及排序顺序,您必须自己编写一些代码,以响应ColumnHeaderClick...