概述
如果要删除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();
}
代码中都有注释,就不多说了。
本篇结束
最后
以上就是内向早晨为你收集整理的在不涉及数据库的情况下,对DataGridView中的数据进行删除操作的全部内容,希望文章能够帮你解决在不涉及数据库的情况下,对DataGridView中的数据进行删除操作所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复