DataGridView验证用户输入

时间:2016-02-20 22:27:29

标签: c# validation datagridview decimal

我有一个DataGridView,它以这种方式填充对象值:

POI_grid.AutoGenerateColumns = true;
POI_grid.DataSource = pois; //pois is an object generated from a class

我希望用户编辑此网格中的一些单元格,但需要进行一些验证。

我目前使用txt框验证用户输入,为了简单起见,我被要求在GridView中执行此操作。我验证用户输入的方式是这样的: (我验证用户是否仅输入十进制数字)

private void txt_X_KeyPress(object sender, KeyPressEventArgs e)
{
    if (((e.KeyChar < 48 || e.KeyChar > 57) && e.KeyChar != 8 && e.KeyChar != '.' && e.KeyChar != '-'))
    {
        e.Handled = true;
    }

    if (e.KeyChar == '.')
    {
        if ((sender as TextBox).Text.IndexOf(e.KeyChar) != -1)
            e.Handled = true;
    }

    if (e.KeyChar == '-' && (sender as TextBox).SelectionStart > 0)
    {
        e.Handled = true;
    }
}

验证用户输入的最佳方法是什么,就像我在文本框中但在DataGridView中一样?

到目前为止,我已经按照Rami的建议尝试了这个:

 private void POI_grid_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            decimal por_x;
            por_x = Convert.ToDecimal(POI_grid.CurrentCell.Value);

        }

当然我需要在那里添加一个try catch语句以避免出现问题,但是在可能的情况下,我想在用户输入单元格时限制用户,就像我在文本框中那样...

解决方案:

以下是我如何解决它:

private void POI_grid_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            decimal por_x;
            try
            {
                por_x = Convert.ToDecimal(POI_grid.CurrentCell.Value);
            }
            catch
            {

               POI_grid.CurrentCell.Value= "0";
            }


        }

        private void POI_grid_DataError(object sender, DataGridViewDataErrorEventArgs e)
        {
            if (e.Exception is FormatException)
            {
                MessageBox.Show("Debe ingresar números decimales solamente", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                MessageBox.Show("Verifique el formato del número ingresado", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

2 个答案:

答案 0 :(得分:1)

我遇到了这样的问题,但最后我没有找到防止用户输入非号码租船人的方法,所以我使用CellEndEdit event来验证输入 如果它无效,则显示消息框(仅数字有效)并将单元格重置为0。 我希望这对你有用。

答案 1 :(得分:0)

以下是我如何解决它:

private void POI_grid_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            decimal por_x;
            try
            {
                por_x = Convert.ToDecimal(POI_grid.CurrentCell.Value);
            }
            catch
            {

               POI_grid.CurrentCell.Value= "0";
            }


        }

        private void POI_grid_DataError(object sender, DataGridViewDataErrorEventArgs e)
        {
            if (e.Exception is FormatException)
            {
                MessageBox.Show("Debe ingresar números decimales solamente", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                MessageBox.Show("Verifique el formato del número ingresado", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }