DataGridView的自定义列排序

1,将需要进行排序的列做属性的设置

this.colUserName.SortMode = DataGridViewColumnSortMode.Programmatic;

2,添加列的事件

//点击列头进行排序
private void dgv_NoSignalSelect_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
int nColumnIndex = e.ColumnIndex;

if (dgv_NoSignalSelect.Columns[nColumnIndex].SortMode != DataGridViewColumnSortMode.Programmatic)
{
return;
}
switch (dgv_NoSignalSelect.Columns[nColumnIndex].HeaderCell.SortGlyphDirection)
{
case SortOrder.None:
case SortOrder.Ascending:
//在这里加入排序的逻辑
OrderTableOgDgv(nColumnIndex, "asc");
//设置列标题的状体
dgv_NoSignalSelect.Columns[nColumnIndex].HeaderCell.SortGlyphDirection = SortOrder.Descending;
break;
default:
//在这里加入排序的逻辑
OrderTableOgDgv(nColumnIndex, "desc");
//设置列标题的状体
dgv_NoSignalSelect.Columns[nColumnIndex].HeaderCell.SortGlyphDirection = SortOrder.Ascending;
break;
}


}

 

3,下面是上面应用到的排序算法

/// <summary>
/// 给dgv_NoSignalSelect按列排序
/// </summary>
/// <param name="nColumnIndex"></param>
/// <param name="orderCmd"></param>
private void OrderTableOgDgv(int nColumnIndex, string orderCmd)
{
DataTableEx dtex = this.dgv_NoSignalSelect.SourceDataTable;
dtex = UserQueueServer.OrderTable(dtex, dgv_NoSignalSelect.Columns[nColumnIndex].Name, orderCmd);
this.dgv_NoSignalSelect.SourceDataTable = dtex;
this.dgv_NoSignalSelect.Refresh();
}

public Class UserQueueServer{

  /// <summary>
/// 对DataTable排序
/// </summary>
/// <param name="dt">DataTableEx</param>
/// <param name="columnname">排序的列名称</param>
/// <param tyoe="type">排序类型 "desc"-降序 "asc"-升序</param>
/// <returns></returns>
public static DataTableEx OrderTable(DataTableEx dt, string columnname,string type)
{
DataTable ds = dt.Clone();
ds.Clear();
if (dt.Columns.Contains(columnname))
{
DataRow[] drs = dt.Select("1=1", columnname + " "+ type);
foreach (DataRow dr in drs)
{
ds.Rows.Add(dr.ItemArray);
}
}
return ds as DataTableEx;
}

}

 

转载于:https://www.cnblogs.com/Robert-huge/p/5542599.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DataGridView是.NET Framework中的一个控件,用于在Windows窗体应用程序中显示和编辑数据。自定义排序是指在DataGridView中对数据进行排序时,根据自定义的规则进行排序。 要实现DataGridView自定义排序,可以按照以下步骤进行操作: 1. 为DataGridView控件的ColumnHeaderMouseClick事件添加事件处理程序。 2. 在事件处理程序中,判断点击的是否需要进行自定义排序。 3. 如果需要进行自定义排序,可以使用DataGridView的Sort方法进行排序。 4. 在Sort方法中,可以使用自定义的比较器来指定排序规则。 5. 自定义比较器可以实现IComparer接口,并重写Compare方法来定义排序规则。 下面是一个示例代码,演示如何实现DataGridView自定义排序: ```csharp private void dataGridView1_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e) { // 判断点击的是否需要进行自定义排序 if (e.ColumnIndex == yourColumnIndex) { // 使用自定义的比较器进行排序 dataGridView1.Sort(new YourCustomComparer()); } } public class YourCustomComparer : IComparer { public int Compare(object x, object y) { // 自定义排序规则,根据需要修改 // 比较x和y的值,返回-1、0或1表示小于、等于或大于 // 例如,按照字符串长度进行排序: string strX = dataGridView1.Rows[(x as DataGridViewRow).Index].Cells[yourColumnIndex].Value.ToString(); string strY = dataGridView1.Rows[(y as DataGridViewRow).Index].Cells[yourColumnIndex].Value.ToString(); return strX.Length.CompareTo(strY.Length); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值