WinForm DataGridView行操作

单行上移

        private void ucBtnUp_Click(object sender, EventArgs e)
        {
            DataGridView dataGridView = new DataGridView();
            DataTable dataTable = new DataTable();
            DataRow newRow;
            DataGridViewRow selectedRow;
            int selectedRowIndex;
            int newRowIndex;

            GetCurrentDataGridView(out dataGridView, out dataTable);//获取表格控件和数据源

            if (dataGridView.SelectedRows.Count > 0)
            {
                selectedRow = dataGridView.SelectedRows[0];
                selectedRowIndex = dataGridView.Rows.IndexOf(selectedRow);
                if (selectedRowIndex >= 1)
                {
                    newRowIndex = selectedRowIndex - 1;
                }
                else
                {
                    newRowIndex = 0;
                }
                newRow = dataTable.NewRow();

                for (int index = 0; index < dataTable.Columns.Count; index++)
                {
                    newRow[index] = dataTable.Rows[selectedRowIndex][index];
                }

                dataTable.Rows.Remove(dataTable.Rows[selectedRowIndex]);
                dataTable.Rows.InsertAt(newRow, newRowIndex);
                dataGridView.ClearSelection();
                dataGridView.Rows[newRowIndex].Selected = true;
            }
        }

单行下移

private void ucBtnDown_Click(object sender, EventArgs e)
{
    DataGridView dataGridView = new DataGridView();
    DataTable dataTable = new DataTable();
    DataRow newRow;
    DataGridViewRow selectedRow;
    int selectedRowIndex;
    int newRowIndex;

     GetCurrentDataGridView(out dataGridView, out dataTable);//获取表格控件和数据

    if (dataGridView.SelectedRows.Count > 0)
    {
        selectedRow = dataGridView.SelectedRows[0];
        selectedRowIndex = dataGridView.Rows.IndexOf(selectedRow);
        if (selectedRowIndex < dataGridView.Rows.Count - 1)
        {
            newRowIndex = selectedRowIndex + 1;
        }
        else
        {
            newRowIndex = dataGridView.Rows.Count - 1;
        }
        newRow = dataTable.NewRow();

        for (int index = 0; index < dataTable.Columns.Count; index++)
        {
            newRow[index] = dataTable.Rows[selectedRowIndex][index];
        }

        dataTable.Rows.Remove(dataTable.Rows[selectedRowIndex]);
        dataTable.Rows.InsertAt(newRow, newRowIndex);
        dataGridView.ClearSelection();
        dataGridView.Rows[newRowIndex].Selected = true;

    }
}

多行上移:


        private void ucBtnUp_Click(object sender, EventArgs e)//多行操作
        {
            DataGridView dataGridView;
            DataTable dataTable;
            int insertRowIndex;
            List<DataRow> byMoveUpRows;
            List<DataRow> newRows;
          GetCurrentDataGridView(out dataGridView, out dataTable);//获取表格控件和数据

            if (dataGridView.SelectedRows.Count > 0)
            {
                dataGridView.ClearSelection();
                insertRowIndex = dataGridView.SelectedRows[dataGridView.SelectedRows.Count - 1].Index - 1;
                byMoveUpRows = new List<DataRow>();
                newRows = new List<DataRow>();

                foreach (DataGridViewCell cell in dataGridView.SelectedCells)
                {
                    if (!byMoveUpRows.Contains(dataTable.Rows[cell.RowIndex]))
                    {
                        byMoveUpRows.Add(dataTable.Rows[cell.RowIndex]);
                    }
                }
                byMoveUpRows.Reverse();
                foreach (DataRow byMoveUpRow in byMoveUpRows)
                {
                    DataRow newRow = dataTable.NewRow();
                    for (int index = 0; index < dataTable.Columns.Count; index++)
                    {
                        newRow[index] = byMoveUpRow[index];
                    }
                    newRows.Add(newRow);
                }

                foreach (DataRow dataRow in byMoveUpRows)
                {
                    dataTable.Rows.Remove(dataRow);
                }

                foreach (DataRow dataRow in newRows)
                {
                    dataTable.Rows.InsertAt(dataRow, insertRowIndex);
                    insertRowIndex++;
                }
            }
        }

复制(通过全局变量实现):

private DataRow byCutOrCopyRow;
private void ucBtnCopy_Click(object sender, EventArgs e)
{
    DataGridView dataGridView = null;
    DataTable dataTable = null;
    DataRow newByCutOrCopyRow = null;
    DataGridViewRow byCutOrCopyRow = null;
    int byCutOrCopyRowIndex;
    int category;

    GetCurrentDataGridView(out dataGridView, out dataTable);

    if (dataGridView.SelectedRows.Count > 0)
    {
        byCutOrCopyRow = dataGridView.SelectedRows[0];
        byCutOrCopyRowIndex = dataGridView.Rows.IndexOf(byCutOrCopyRow);
        newByCutOrCopyRow = dataTable.NewRow();

        for (int index = 0; index < dataTable.Columns.Count; index++)
        {
            newByCutOrCopyRow[index] = dataTable.Rows[byCutOrCopyRowIndex][index];
        }
    byCutOrCopyRow= newByCutOrCopyRow;
    }
}

剪切(通过全局变量实现):

private DataRow byCutOrCopyRow;
private void ucBtnCut_Click(object sender, EventArgs e)
{
    DataGridView dataGridView = new DataGridView();
    DataTable dataTable = new DataTable();
    DataRow newByCutOrCopyRow;
    DataGridViewRow byCutOrCopyRow;
    int byCutOrCopyRowIndex;
    int category;

    GetTabLeftCurrentDataGridView(out dataGridView, out dataTable, out _);

    if (dataGridView.SelectedRows.Count > 0)
    {
        byCutOrCopyRow = dataGridView.SelectedRows[0];
        byCutOrCopyRowIndex = dataGridView.Rows.IndexOf(byCutOrCopyRow);
        newByCutOrCopyRow = dataTable.NewRow();

        for (int index = 0; index < dataTable.Columns.Count; index++)
        {
            newByCutOrCopyRow[index] = dataTable.Rows[byCutOrCopyRowIndex][index];
        }


        dataTable.Rows.Remove(dataTable.Rows[byCutOrCopyRowIndex]);
        dataGridView.ClearSelection();
            byCutOrCopyRow= newByCutOrCopyRow;
     

    }
}

粘贴(通过全局变量实现):

private DataRow byCutOrCopyRow;
private void ucBtnPaste_Click(object sender, EventArgs e)
{
    DataGridView dataGridView = null;
    DataTable dataTable = null;
    DataRow byCutOrCopyRow = null;
    DataRow newRow = null;
    DataGridViewRow selectedRow = null;
    int selectedRowIndex;
    int category;

    GetCurrentDataGridView(out dataGridView, out dataTable);

    if (dataGridView.SelectedRows.Count > 0)
    {

        dataTable = (DataTable)dataGridView.DataSource;
        newRow = dataTable.NewRow();
        selectedRow = dataGridView.SelectedRows[0];
        selectedRowIndex = dataGridView.Rows.IndexOf(selectedRow);



        for (int index = 0; index < dataTable.Columns.Count; index++)
        {
            newRow[index] = byCutOrCopyRow[index];
        }
        dataTable.Rows.InsertAt(newRow, selectedRowIndex + 1);
        dataGridView.ClearSelection();

       
      
        dataGridView.Rows[selectedRowIndex + 1].Selected = true;
       

    }


}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值