【问题标题】:Change datagridview cell value in edit mode在编辑模式下更改 datagridview 单元格值
【发布时间】:2015-08-16 09:53:06
【问题描述】:

我在 datagridview 中有一个单元格,我在其中以自定义格式显示时间。我需要在使用时进入编辑模式(例如通过双击),我需要将字符串值更改为以分钟为单位表示时间的整数。

当我尝试更改“CellEnter”事件中的单元格值时,它似乎没有响应。实际上,它似乎并没有在任何事件中改变单元格值。

请不要介意将时间转换为字符串的细节,反之亦然,我的问题是如何在用户双击单元格时成功更改单元格的内容。

编辑(代码+解决方案): 我所做的是使用另一列来存储实际值(没有格式化)。在该列的单元格格式上,我将值传递给自定义格式函数以填充我的列。

private void gridview_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e)
{
    if (e.ColumnIndex == 3 && e.Value != null && e.Value.ToString() != "")
    {
        //fill the unbound textbox column (5) from raw value column (3)
        string newValue = TimeAttendanceHelper.FormatHourlyDuration(e.Value);
        gridview.Rows[e.RowIndex].Cells[5].Value = newValue;
    }
}

然后感谢 TaW,在 CellBeginEdit 上,我显示了原始值来编辑它:

private void gridview_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
{
    if (e.ColumnIndex == 5)
    {
        //on editing, use the value from raw data column (3)
        gridview.Rows[e.RowIndex].Cells[5].Value = gridview.Rows[e.RowIndex].Cells[3].Value;
    }
}

最后,当 CellEndEdit 时,我重新格式化新值:

private void gridview_CellEndEdit(object sender, DataGridViewCellEventArgs e)
{
    if (e.ColumnIndex == 4)
    {
        //update value both in columns 3 & 5
        string newValue = tIME_SHIFTDataGridView.Rows[e.RowIndex].Cells[4].Value.ToString();
        gridview.Rows[e.RowIndex].Cells[3].Value = newValue;
        gridview.Rows[e.RowIndex].Cells[4].Value = TimeAttendanceHelper.FormatHourlyDuration(newValue);
    }
}

【问题讨论】:

  • 请在示例数据中包含您的代码 sn-p 并突出显示有问题的部分。最好的问候,
  • 您可以将您的代码添加到帖子中吗?
  • 您的代码...请...
  • 没有什么要添加的代码,但它就在这里。

标签: c# winforms datagridview


【解决方案1】:

当单元格处于编辑模式时,您需要更改编辑控件中的文本,通常是文本框。您可以在EditingControlShowing 事件中获取(并持有)它的句柄:

TextBox editBox = null;

private void dataGridView1_EditingControlShowing(object sender,
                           DataGridViewEditingControlShowingEventArgs e)
{
    if (e.Control is TextBox) editBox = e.Control as TextBox;
}

但是使用CellEnter 事件并不是一个好主意,因为它也会在滚动或点击时被调用..

要捕捉编辑的开始,请使用 BeginEdit 事件:

int yourEditColumn = 5;

private void dataGridView1_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
{
    if (e.ColumnIndex == yourEditColumn )
    {
        string yourValue = "12345";
        dataGridView1.Rows[e.RowIndex].Cells[yourEditColumn ].Value = yourValue;
        if (editBox != null)   editBox.Text = yourValue;
    }
}

【讨论】:

  • 现在我需要通过格式化另一列的值来填充未绑定的文本框列。我曾经在 CellFormatting 活动中这样做,但现在对我不利。我需要另一个事件来填充 datagridview 单元格中的数据。
  • CellFormatting 发生在数据格式化之前。您始终可以通过 Cell.FormattedValue 属性访问格式化值。
  • 我不太关心 CellFormatting 事件。我需要一个替换事件,在该事件中我可以将数据从一个单元格复制到同一行中的另一个单元格。
猜你喜欢
  • 2014-11-20
  • 2010-12-21
  • 1970-01-01
  • 1970-01-01
  • 2011-07-11
  • 1970-01-01
  • 1970-01-01
  • 2012-04-05
  • 1970-01-01
相关资源
最近更新 更多