前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WinForm中DataGridView验证单元格输入的是数字

WinForm中DataGridView验证单元格输入的是数字

作者头像
跟着阿笨一起玩NET
发布2018-09-20 15:04:47
2.1K0
发布2018-09-20 15:04:47
举报

     事件:DataGridView验证单元格输入的是数字,DataGridView源数据是从数据库读取的。

     需求:当用户输入的不是数字的时候需要提示信息(数据是直接绑定数据库的,因此dataGridView有自己的报错功能,我们需要屏蔽掉它,显示自己的错误提示!)

     实现: 选择DataGridView的CellValidating事件

      (1)  验证整数:

 1  private void gridPlant_CellValidating(object sender, DataGridViewCellValidatingEventArgs e)
 2         {
 3             if (e.RowIndex > -1 && e.ColumnIndex > -1)
 4             {
 5                 DataGridView grid = (DataGridView)sender;
 6                 grid.Rows[e.RowIndex].ErrorText = "";
 7                //这里最好用列名,而不是列索引号做判断
 8                 if (grid.Columns[e.ColumnIndex].Name == "WO0011_NUMBER_IDLE" || grid.Columns[e.ColumnIndex].Name == "WO0011_NUMBER_WORKING" || grid.Columns[e.ColumnIndex].Name == "WO0011_NUMBER_ON_SITE")
 9                 {
10 
11                     Int32 newInteger = 0;
12                     if (!int.TryParse(e.FormattedValue.ToString(), out newInteger))
13                     {
14                         e.Cancel = true;
15                         grid.Rows[e.RowIndex].ErrorText = "Please enter a int number!";
16                         MessageBox.Show("the value is not nubmer , Pleaser enter a int number !");
17                         return;
18                     }
19                 }
20             }
21         }

     (2) 验证十进制数:

 1  private void gridBriefsOlder_CellValidating(object sender, DataGridViewCellValidatingEventArgs e)
 2         {
 3             if (e.RowIndex > -1 && e.ColumnIndex > -1)
 4             {
 5                 DataGridView grid = (DataGridView)sender;
 6                 grid.Rows[e.RowIndex].ErrorText = "";
 7 
 8                 if (grid.Columns[e.ColumnIndex].Name == "WO0009_APPROXIMATE_COMPLETION_PERCENTAGE1")
 9                 {
10                     try
11                     {
12                         Convert.ToDecimal(e.FormattedValue);
13                     }
14                     catch
15                     {
16                         e.Cancel = true;
17                         grid.Rows[e.RowIndex].ErrorText = "Please enter a number!";
18                         MessageBox.Show("the value is not nubmer , Pleaser enter a  number !");
19                         return;
20                     }
21                 }
22             }
23         }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013-02-18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档