C# DataGridView 限制单元格输入时遇到的问题

本文详细讲述了如何在DataGridView中实现不同列的输入限制,修正了第一列被误限为只能输入数字的问题。通过添加和移除事件处理器,确保第一列允许全类型输入,而第二列强制数字输入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

限制单元格输入的实现方法:

添加DataGridView的EditingControlShowing事件,代码如下:

private void DataGridView1_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
{
      if(e.Control is DataGridViewTextBoxEditingControl tb)
      {
           DataGridView dgv = sender as DataGridView;

           if (dgv.CurrentCell.ColumnIndex > 0)
           {
               tb.ShortcutsEnabled = false;
               tb.ImeMode = ImeMode.Disable;
               tb.SelectAll();

               tb.KeyPress -= new KeyPressEventHandler(CellEdit_KeyPress);
               tb.KeyPress += new KeyPressEventHandler(CellEdit_KeyPress);
           }
    }
}

软件需求,第一列输入不限制,输入汉字、英文、数字...都可以,第二列必须输入数字。

使用发现,只要激活第二列的单元格后,第一列就只能输入数字了。与实际需求相反

分析,整个DataGridView控件编辑单元格,只用一个DataGridViewTextBoxEditingControl 类型的控件实现输入。因此,激活第一列单元格后添加了限制。以后就被限制了。修改代码如下&#x

C# 中,如果你想要限制 DataGridView 控件中的单元格只允许用户输入数字,你可以通过以下几个步骤来实现: 1. **数据属性**:首先,确保 DataGridView 的 `DataSource` 已经设置,并且相应的列(DataGridViewColumn)是 `DataGridViewTextBoxColumn` 类型,因为它是用于存储单一值的数据。 ```csharp DataGridViewTextBoxColumn numericColumn = new DataGridViewTextBoxColumn(); numericColumn.DataPropertyName = "ColumnName"; // 替换为实际数据源中的列名 numericColumn.DefaultCellStyle.Format = "N2"; // 设置默认数值格式,例如保留两位小数 ``` 2. **验证事件**:添加事件处理器到单元格编辑期间的 `Validating` 事件,检查输入是否符合要求。可以创建一个简单的正则表达式来匹配数字: ```csharp private void dataGridView_CellValidating(object sender, DataGridViewCellValidatingEventArgs e) { if (e.ColumnIndex == numericColumn.Index && !Regex.IsMatch(e.FormattedValue.ToString(), @"^-?\d+(\.\d+)?$")) // 正则表达式,只允许整数或小数 { e.Cancel = true; e.ErrorText = "请输入数字"; } } ``` 3. **焦点失去事件**:还可以处理 `LostFocus` 事件,防止用户离开单元格带入非数字字符: ```csharp private void dataGridView_CellLostFocus(object sender, DataGridViewCellEventArgs e) { if (e.ColumnIndex == numericColumn.Index && !Regex.IsMatch(sender.Rows[e.RowIndex].Cells[numericColumn.Index].Value?.ToString(), @"^-?\d+(\.\d+)?$")) { sender.Rows[e.RowIndex].Cells[numericColumn.Index].Value = null; // 清除非法输入 } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值