C# Winform 中验证DataGridView单元格内容

 

C# Winform 中验证DataGridView单元格内容--限制单元格中只能输入数字

 

为避免在DataGridView的单元格中输入错误的数据类型导致保存错误,可以用下面代码解决:

 

1、先设置DataGridView只能输入数字的列的外观属性:(见图1

DefaultCellStyle为:DataGridViewCellStyle { NullValue=0, Format=N2}

其中,NullValue=0表示此单元格为空时的默认值为0Format=N2则代表格式化

1

 

2、然后编写DataGridViewEditingControlShowing事件:

TextBox control;    //定义输入框控件对象

private  void  dataGridView1_EditingControlShowing(object sender,

  DataGridViewEditingControlShowingEventArgs e)

{

//只对TextBox类型的单元格进行验证

    if (e.Control.GetType().BaseType.Name == "TextBox") 

    {

        control = new TextBox();

        control = (TextBox)e.Control;

        if (control.Text == "0")    //需要限制输入数字的单元格

        {

            control.KeyPress += new KeyPressEventHandler(control_KeyPress);

        }

        else

        {

            //非数字类型单元格

            control.Leave += new EventHandler(control_Leave);

        }

    }

}

 

void control_KeyPress(object sender, KeyPressEventArgs e)

{

    //限制只能输入-9的数字,退格键,小数点和回车

    if (((int)e.KeyChar >= 48 && (int)e.KeyChar <= 57) || e.KeyChar == 13 || e.KeyChar == 8 || e.KeyChar == 46)

    {

        e.Handled = false;

    }

    else

    {

        e.Handled = true;

        MessageBox.Show("只能输入数字!");

    }

}

 

void control_Leave(object sender, EventArgs e)

{

    //如果需要限制字符串输入长度

    if (control.Text.Length != 11)

    {

        MessageBox.Show("只能为位!");

        control.Focus();

    }

}

 

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在C# WinForm合并任意单元格,你可以通过以下步骤: 1. 首先,你需要在DataGridView控件选择要合并的单元格。 2. 然后,你可以编写代码来合并选定的单元格。你可以使用CellPainting事件来自定义单元格的外观并将其合并。 下面是一个示例代码: ```csharp private void dataGridView1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e) { if (e.RowIndex == 0 && e.ColumnIndex == 0) { e.AdvancedBorderStyle.Bottom = DataGridViewAdvancedCellBorderStyle.None; e.AdvancedBorderStyle.Right = DataGridViewAdvancedCellBorderStyle.None; } else if (e.RowIndex == 0) { e.AdvancedBorderStyle.Bottom = DataGridViewAdvancedCellBorderStyle.None; if (dataGridView1[e.ColumnIndex, e.RowIndex].Value.ToString() == dataGridView1[e.ColumnIndex - 1, e.RowIndex].Value.ToString()) { e.AdvancedBorderStyle.Left = DataGridViewAdvancedCellBorderStyle.None; } } else if (e.ColumnIndex == 0) { e.AdvancedBorderStyle.Right = DataGridViewAdvancedCellBorderStyle.None; if (dataGridView1[e.ColumnIndex, e.RowIndex].Value.ToString() == dataGridView1[e.ColumnIndex, e.RowIndex - 1].Value.ToString()) { e.AdvancedBorderStyle.Top = DataGridViewAdvancedCellBorderStyle.None; } } else { if (dataGridView1[e.ColumnIndex, e.RowIndex].Value.ToString() == dataGridView1[e.ColumnIndex - 1, e.RowIndex].Value.ToString()) { e.AdvancedBorderStyle.Left = DataGridViewAdvancedCellBorderStyle.None; } if (dataGridView1[e.ColumnIndex, e.RowIndex].Value.ToString() == dataGridView1[e.ColumnIndex, e.RowIndex - 1].Value.ToString()) { e.AdvancedBorderStyle.Top = DataGridViewAdvancedCellBorderStyle.None; } } } ``` 这段代码会检查选定单元格的值,如果相邻单元格的值相同,则将相邻单元格的边框样式设置为None,从而实现单元格的合并。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值