在不涉及数据库的情况下,对DataGridView中的数据进行删除操作

    如果要删除DataGridView中的一行数据,有个比较快捷方便的方法,那就是可以选中该行,然后按<Del>键就可以删除了。现在我想实现的是随便点中某行的某个Cell,然后点击”删除“按钮来实现删除该行,也可以选中多行一起删除。首先贴上操作图比较好理解我说的是什么意思:

第一种删除方法:

    选中要删除的行,然后按键盘上的<Del>或者写着<Delete>的键,删除该行:

删除前:

删除后:


第二种删除方法(自己写代码实现):

删除前:

删除后:


代码实现如下:

private void deleteDatabaseButton_Click(object sender, EventArgs e)
{
    // Dictionary<factID, rowNum> dicts;这句东西只是方便知道我这个Dictionary放的是什么内容
    Dictionary<int, int> dicts = new Dictionary<int, int>();

    // 得到选中的行(不管是以整行选中,还是只是选中某行的某个单元,认为选中了该行),并且把这行的东西放到Dictionary里面
    int key;
    foreach (DataGridViewCell cell in curDGV.SelectedCells)
    {
        key = Convert.ToInt32(curDGV.Rows[cell.RowIndex].Cells[0].Value);
        if (!dicts.ContainsKey(key))
        {
            dicts.Add(key, cell.RowIndex);  // 其中cell.RowIndex是要删除的行
        }
    }          

    // 把准备要删除的行放进一个List中
    List<DataGridViewRow> lists = new List<DataGridViewRow>();
    foreach(var dict in dicts)
    {
        if(mainDict.ContainsKey(dict.Key))
        {
			// 这句mainDict....什么的与本例无关,只是用来作辅助,判断从其他DataGridView加进来的数据是否已经存在时用到,
			// 这里如果删除了就要相应删除字典里面保存的key值而已
			mainDict.Remove(dict.Key);
            lists.Add(curDGV.Rows[dict.Value]);  // 记录要删除的行
        }
    }
			
    // 开始执行删除
    foreach(var row in lists)
    {
        curDGV.Rows.Remove(row);  // 删除所选的行数据
    }

    // 更新
    //curDGV.Refresh();
}


代码中都有注释,就不多说了。


本篇结束

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值