winform零基础学习(十)—dataGridView(基本用法+获得选中单元的值及其行列索引+删除行)

一、
当我们在窗体中使用表格时会发现,在编辑每一列的列标题后,第一例为空白,如图所示。
在这里插入图片描述
那如何把第一列的空白给去掉呢?
其实,第一列空白为每行的行标题,当我们不需要的时候,右击控件选择属性,找到RowHeadersVisible改为False即可。同样道理,第一行也是每一列的列标题,再不需要显示的时候找到属性中的CoulmnHeadersVisible改为False即可。
在这里插入图片描述
要想向表格中添加数据可以使用Colunms和Rows属性。

        private void Form1_Load(object sender, EventArgs e)
        {
            string[] row1 = new string[] { "0001", "小吕", "男", "18890234567" };
            string[] row2 = new string[] { "0002", "小张", "男", "18890232343" };
            string[] row3 = new string[] { "0003", "小王", "女", "18890238798" };
            string[] row4 = new string[] { "0004", "小朱", "男", "18890234566" };
            object[] rows = new object[] { row1, row2, row3, row4 };
            foreach (string[] i in rows)//使用foreach语句循环添加
            {
                dataGridView1.Rows.Add(i);//向控件中添加数据
            }
        }

运行后的效果:
在这里插入图片描述
此时会发现多处一行空白行,当鼠标点击空白单元格时发现可以手动添加数据,如果不想显示空白行,可以在控件的属性中找到AllowUserAddToRows改成False即可。
在这里插入图片描述
单击已经添加好的数据也可以进行编辑,那如果我们不想对已添加的数据进行编辑,只需要在属性中把ReadOnly改为True即可。

二、获得选中单元的值及其行列索引

        string XY;//所选单元格的值
        int rowIndex;//行索引
        int colIndex;//列索引
        private void dataGridView_CellEnter(object sender, DataGridViewCellEventArgs e)
        {
            //所选单元格的值
            XY = dataGridcoordinates.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString();=
            //获取当前单元格的行号和列号
            rowIndex = e.RowIndex;
            colIndex = e.ColumnIndex;=
        }

三、删除选中行
1.

删除选中格所在行
            int i = dataGridcoordinates.SelectedCells[0].RowIndex;
            dataGridcoordinates.Rows.RemoveAt(i);

2.只想删除选中单元格,本人未找到方法,用null来代替
用二结合下一行代码即可实现

dataGridcoordinates.Rows[rowIndex].Cells[colIndex].Value = null;

若想更改后台数据,可以将数据存入list,再根据list[rowIndex]直接更改替换的数据

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在Winform DataGridView删除,可以使用以下步骤: 1. 获取删除索引或对象。 2. 调用DataGridView.Rows.Remove方法删除。 例如,以下代码删除选定的: ``` if (dataGridView1.SelectedRows.Count > 0) { dataGridView1.Rows.Remove(dataGridView1.SelectedRows[0]); } ``` 或者,以下代码删除指定索引: ``` dataGridView1.Rows.RemoveAt(2); ``` 请注意,删除时,如果该包含任何关联的数据,您需要确保同时删除这些数据,以避免数据不一致。 ### 回答2: Winform DataGridView(数据表格)是一种非常常用的用户界面控件,通常用于展示和编辑大量数据。在使用DataGridView时,通常需要对数据进增、删、改操作。本文将着重介绍在Winform DataGridView删除的方法。 Winform DataGridView提供了几种方式来删除数据,具体有两种:删除选择的删除指定的。 1. 删除选择的Winform DataGridView选中想要删除,然后在代码中调用DataGridView的方法即可: ``` dataGridView1.Rows.Remove(dataGridView1.SelectedRows[0]); ``` 这段代码首先使用了SelectedRows属性来获取当前被选择的,然后调用Rows的Remove()方法,该方法会将数据从DataGridView删除,同时也会从数据源中删除。 2. 删除指定的 如果要删除DataGridView中指定的,则需指定该索引,即调用Rows.RemoveAt()方法: ``` dataGridView1.Rows.RemoveAt(3); ``` 这段代码会删除DataGridView中的第4索引从0开始)。 然而,如果要在Winform DataGridView删除,我们还需要注意以下几点: 1. 不要在foreach循环中删除C#中,如果在foreach循环中删除元素会报错。因为当你删除一个元素时,集合的大小发生了变化,此时foreach无法正确地读取集合,所以会出现错误。因此,建议使用for循环,倒序删除元素。 2. 数据源和DataGridView应该同步 删除DataGridView中的数据时,应该同步更新数据源中的数据,否则当重新加载数据时,删除的数据会再次出现。删除数据源中的数据可以调用相关方法,如DataTable或BindingList的Remove方法。 3. 不要忽略删除的异常 在某些情况下,无法删除DataGridView中的。例如,如果正在编辑该时,或者该处于锁定状态,则删除操作会引发异常。因此,应该使用try-catch语句处理这些异常。 总的来说,Winform DataGridView删除非常简单,但在实际应用中还是有很多需要注意的地方。只有注意这些细节,才能保证程序的稳定性和可靠性。 ### 回答3: Winform中的DataGridView为我们提供了一种非常方便的方式来展示和编辑数据。 DataGridView控件的删除操作,通常分为两种:一种是从数据源中删除该数据所占用的,并同时将DataGridView删除掉;另一种是只将DataGridView删除掉,而不直接影响数据源中的数据。 下面针对这两种情况,给大家详细介绍DataGridView删除操作: 1. 删除DataGridView中的,不影响数据源中的数据 在DataGridView中,删除只需要调用控件的Rows.RemoveAt()方法即可,该方法接收一个int类型的参数,表示要删除索引位置。 代码示例: ``` private void btnDelete_Click(object sender, EventArgs e) { if (dgvData.SelectedRows.Count > 0) { dgvData.Rows.RemoveAt(dgvData.SelectedRows[0].Index); } } ``` 2. 删除DataGridView中的,并从数据源中同时删除该数据 删除DataGridView中的数据和同时从数据源中删除数据,这种情况比第一种情况复杂一些。 当我们对DataGridView中的数据进删除操作时,需要注意以下几点: - DataGridView绑定的数据源必须是可编辑的,比如List、DataTable等; - 删除DataGridView后,需要将数据源中对应的数据也删除; - 数据源改变后,需要重新绑定到DataGridView控件上。 代码示例: ``` private void btnDelete_Click(object sender, EventArgs e) { if (dgvData.SelectedRows.Count > 0) { // 获取当前选中数据的索引 int index = dgvData.SelectedRows[0].Index; // 从数据源中删除数据 (dgvData.DataSource as DataTable).Rows.RemoveAt(index); // 刷新DataGridView dgvData.DataSource = dgvData.DataSource; } } ``` 以上就是针对Winform中的DataGridView删除的操作方法,希望能对大家有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值