datagridview 列排序问题

本文介绍如何使用 DataGridView 控件实现自动排序功能,包括设置 SortMode 属性、响应不同事件触发排序及手动排序的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

DataGridViewColumn.SortMode属性为DataGridViewColumnSortMode.Automatic时,用 户点击列Header时,可以对列的内容进行排序。使用程序排序时,可以使用DataGridView.Sort方法实现。但排序后如果SortMode 属性为Automatic或Programmatic时,用户点击列Header时也可以进行排序。


补充:MSDN的「DataGridViewRowCollection.Add方法」, 添加新行时,控件中的行不自动排序。若要将新行排序为正确的位置,请在DataGridView.RowsAdded事件处理器中调用 System.Windows.Forms.DataGridView.Sort方法。可能还需要在CellValueChanged 事件处理器中调用 System.Windows.Forms.DataGridView.Sort方法,以便在用户修改单元格时对行进行排序。


下面的代码是,点击Button1时,当前单元格的列进行排序。如果当前列和已排序不是同一列时以升序排序的例子。


[VB.NET]


 '窗体的Load事件处理器
 Private Sub Form1_Load(ByVal sender As System.Object, _
         ByVal e As System.EventArgs) Handles MyBase.Load
     '自动排序
     Dim c As DataGridViewColumn
     For Each c In DataGridView1.Columns
         c.SortMode = DataGridViewColumnSortMode.Automatic
     Next c
 End Sub


 'Button1的Click事件处理器
 Private Sub Button1_Click(ByVal sender As System.Object, _
         ByVal e As System.EventArgs) Handles Button1.Click
     If DataGridView1.CurrentCell Is Nothing Then
         Return
     End If
 
     '设定排序的列
     Dim sortColumn As DataGridViewColumn = _
         DataGridView1.CurrentCell.OwningColumn
 
     '设定排序的方向(升序、降序)
     Dim sortDirection As System.ComponentModel.ListSortDirection = _
         System.ComponentModel.ListSortDirection.Ascending
     If Not (DataGridView1.SortedColumn Is Nothing) AndAlso _
             DataGridView1.SortedColumn.Equals(sortColumn) Then
         sortDirection = IIf(DataGridView1.SortOrder = SortOrder.Ascending, _
             System.ComponentModel.ListSortDirection.Descending, _
             System.ComponentModel.ListSortDirection.Ascending)
     End If


     '进行排序
     DataGridView1.Sort(sortColumn, sortDirection)
 End Sub


[C#]


 //窗体的Load事件处理器
 private void Form1_Load(object sender, EventArgs e)
 {
     //自动排序
     foreach (DataGridViewColumn c in DataGridView1.Columns)
         c.SortMode = DataGridViewColumnSortMode.Automatic;
 }


 // Button1的Click事件处理器
 private void Button1_Click(object sender, EventArgs e)
 {
     if (DataGridView1.CurrentCell == null)
         return;


     //设定排序的列
     DataGridViewColumn sortColumn = DataGridView1.CurrentCell.OwningColumn;


     //设定排序的方向(升序、降序)
     ListSortDirection sortDirection = ListSortDirection.Ascending;
     if (DataGridView1.SortedColumn != null &&
         DataGridView1.SortedColumn.Equals(sortColumn))
     {
         sortDirection =
             DataGridView1.SortOrder == SortOrder.Ascending ?
             ListSortDirection.Descending : ListSortDirection.Ascending;
     }


     //进行排序
     DataGridView1.Sort(sortColumn, sortDirection);
 }
不能自动排序时也能自动排序


不能自动排序时,可以自己进行排序。也就是说当SortMode属性为Programmatic时,使用排序图标(在列Header右侧表示的,可以进行升序、降序排序的图标)进行排序。


列 Header点击时进行排序时是使用DataGridView.ColumnHeaderMouseClick事件处理器触发Sort方法实现的。在新行 追加后、单元格的值被编辑后,是使用RowsAdded或CellValueChanged事件处理器触发Sort方法实现。


排序的图标表示是通过DataGridViewColumnHeaderCell.SortGlyphDirection属性设定的。


[VB.NET]
 
 'ColumnHeaderMouseClick事件处理器
 Private Sub DataGridView1_ColumnHeaderMouseClick(ByVal sender As Object, _
         ByVal e As DataGridViewCellMouseEventArgs) _
         Handles DataGridView1.ColumnHeaderMouseClick
     Dim clickedColumn As DataGridViewColumn = _
         DataGridView1.Columns(e.ColumnIndex)
     If clickedColumn.SortMode <> DataGridViewColumnSortMode.Automatic Then
         Me.SortRows(clickedColumn, True)
     End If
 End Sub


 'RowsAdded事件处理器
 Private Sub DataGridView1_RowsAdded(ByVal sender As Object, _
         ByVal e As DataGridViewRowsAddedEventArgs) _
         Handles DataGridView1.RowsAdded
     Me.SortRows(DataGridView1.SortedColumn, False)
 End Sub


 'CellValueChanged事件处理器
 Private Sub DataGridView1_CellValueChanged(ByVal sender As Object, _
         ByVal e As DataGridViewCellEventArgs) _
         Handles DataGridView1.CellValueChanged
     If Not (DataGridView1.SortedColumn Is Nothing) AndAlso _
         e.ColumnIndex = DataGridView1.SortedColumn.Index Then
         Me.SortRows(DataGridView1.SortedColumn, False)
     End If
 End Sub


 ''' <summary>
 ''' 以被指定的列为标准进行排序
 ''' </summary>
 ''' <param name="sortColumn">为标准的列</param>
 ''' <param name="orderToggle">变更排序方向的Toggle</param>
 Private Sub SortRows(ByVal sortColumn As DataGridViewColumn, _
         ByVal orderToggle As Boolean)
     If sortColumn Is Nothing Then
         Return
     End If


     '清除前面的排序
     If sortColumn.SortMode = DataGridViewColumnSortMode.Programmatic AndAlso _
         Not (DataGridView1.SortedColumn Is Nothing) AndAlso _
         Not DataGridView1.SortedColumn.Equals(sortColumn) Then
         DataGridView1.SortedColumn.HeaderCell.SortGlyphDirection = _
             SortOrder.None
     End If


     '设定排序的方向(升序、降序)
     Dim sortDirection As System.ComponentModel.ListSortDirection
     If orderToggle Then
         sortDirection = IIf(DataGridView1.SortOrder = SortOrder.Descending, _
             System.ComponentModel.ListSortDirection.Ascending, _
             System.ComponentModel.ListSortDirection.Descending)
     Else
         sortDirection = IIf(DataGridView1.SortOrder = SortOrder.Descending, _
             System.ComponentModel.ListSortDirection.Descending, _
             System.ComponentModel.ListSortDirection.Ascending)
     End If
     Dim sOrder As SortOrder = _
         IIf(sortDirection = System.ComponentModel.ListSortDirection.Ascending, _
             SortOrder.Ascending, SortOrder.Descending)
 
     '进行排序
     DataGridView1.Sort(sortColumn, sortDirection)
 
     If sortColumn.SortMode = DataGridViewColumnSortMode.Programmatic Then
         '变更排序图标
         sortColumn.HeaderCell.SortGlyphDirection = sOrder
     End If
 End Sub


[C#]


 //窗体的Load事件处理器
 private void Form1_Load(object sender, EventArgs e)
 {
     //事件处理器的追加
     DataGridView1.RowsAdded += new DataGridViewRowsAddedEventHandler(
         DataGridView1_RowsAdded);
     DataGridView1.CellValueChanged += new DataGridViewCellEventHandler(
         DataGridView1_CellValueChanged);
     DataGridView1.ColumnHeaderMouseClick += new DataGridViewCellMouseEventHandler(
         DataGridView1_ColumnHeaderMouseClick);
 }


 //ColumnHeaderMouseClick事件处理器
 private void DataGridView1_ColumnHeaderMouseClick(object sender,
     DataGridViewCellMouseEventArgs e)
 {
     DataGridViewColumn clickedColumn = DataGridView1.Columns[e.ColumnIndex];
     if (clickedColumn.SortMode != DataGridViewColumnSortMode.Automatic)
         this.SortRows(clickedColumn, true);
 }


 //RowsAdded事件处理器
 private void DataGridView1_RowsAdded(object sender,
     DataGridViewRowsAddedEventArgs e)
 {
     this.SortRows(DataGridView1.SortedColumn, false);
 }


 //CellValueChanged事件处理器
 private void DataGridView1_CellValueChanged(object sender,
     DataGridViewCellEventArgs e)
 {
     if (DataGridView1.SortedColumn != null &&
         e.ColumnIndex == DataGridView1.SortedColumn.Index)
         this.SortRows(DataGridView1.SortedColumn, false);
 }


 /// <summary>
 ///以被指定的列为标准进行排序
 /// </summary>
 /// <param name="sortColumn">为标准的列</param>
 /// <param name="orderToggle">变更排序方向的Toggle </param>
 private void SortRows(DataGridViewColumn sortColumn, bool orderToggle)
 {
     if (sortColumn == null)
         return;
 
     //清除前面的排序
     if (sortColumn.SortMode == DataGridViewColumnSortMode.Programmatic &&
         DataGridView1.SortedColumn != null &&
         !DataGridView1.SortedColumn.Equals(sortColumn))
     {
         DataGridView1.SortedColumn.HeaderCell.SortGlyphDirection =
             SortOrder.None;
     }
 
     //设定排序的方向(升序、降序)
     ListSortDirection sortDirection;
     if (orderToggle)
     {
         sortDirection =
             DataGridView1.SortOrder == SortOrder.Descending ?
             ListSortDirection.Ascending : ListSortDirection.Descending;
     }
     else
     {
         sortDirection =
             DataGridView1.SortOrder == SortOrder.Descending ?
             ListSortDirection.Descending : ListSortDirection.Ascending;
     }
     SortOrder sortOrder =
         sortDirection == ListSortDirection.Ascending ?
         SortOrder.Ascending : SortOrder.Descending;
 
     //进行排序
     DataGridView1.Sort(sortColumn, sortDirection);


     if (sortColumn.SortMode == DataGridViewColumnSortMode.Programmatic)
     {
         //变更排序图标
         sortColumn.HeaderCell.SortGlyphDirection = sortOrder;
     }
 }
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView不表示和删除 DataGridView控件用法合集(二) 7. DataGridView宽度高度设置为不能编辑 8. DataGridView行高幅自动调整 9. DataGridView指定行冻结 10. DataGridView顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView排序(点击表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值