如何检查用户是否在文本字段中输入了数字?如果他们确实输入了除文本之外的数据,我想要显示错误消息并循环返回以再次输入他们的输入..任何帮助将不胜感激。感谢。
以下是代码:
myCmd.CommandText = "INSERT INTO Guest(Guest_First_Name, Guest_Surname, Guest_Address, Guest_Postcode, Guest_Telephone, [Guest_E-mail])" + "VALUES(@Fname, @Sname, @Address, @Postcode, @Telephone, @Email)";
myCmd.Parameters.Add("@Fname", OleDbType.Char).Value = firstName.Text;
myCmd.Parameters.Add("@Sname", OleDbType.Char).Value = surname.Text;
myCmd.Parameters.Add("@Address", OleDbType.Char).Value = address.Text;
myCmd.Parameters.Add("@Postcode", OleDbType.Char).Value = postcode.Text;
myCmd.Parameters.Add("@Telephone", OleDbType.Char).Value = telephone.Text;
myCmd.Parameters.Add("@Email", OleDbType.Char).Value = email.Text;
connect.Open();
int rowsChanged = myCmd.ExecuteNonQuery();
connect.Close();
if (rowsChanged == 1)
{
MessageBox.Show("Record Inserted");
}
else
{
MessageBox.Show("Error: Record Not Inserted");
}
答案 0 :(得分:2)
让我们假设textField是字段的名称。然后,您可以在C#中执行以下操作: -
int num=0;
if(!(Int32.TryParse(textField,out num)))
{
Console.WriteLine("Error");
return; // return an error at this point
}
您还可以尝试以下(未经测试): -
int num=0;
if(!(Int32.TryParse(textField,NumberStyles.None,CultureInfo.InvariantCulture,out num)))
{
Console.WriteLine("Error");
return; // return an error at this point
}
在第一个示例中,NumberStyles默认为Integer。将其更改为无可能会有所帮助。
答案 1 :(得分:1)
可以使用这样的东西:
private void textBox1_TextChanged(object sender, EventArgs e)
{
textBox1.Text = string.Concat(textBox1.Text.Where(char.IsLetter));
}
这不会显示任何错误;除了字母以外的任何内容都会被删除。
答案 2 :(得分:0)
int result;
if (int.TryParse(input.Text, out result))
{
// it's a valid integer => you could use the result variable here
}
或者如果你想在按键中验证,
private void txtbox1_KeyPress(object sender, KeyPressEventArgs e)
{
if (e.KeyChar >= '0' && e.KeyChar <= '9' || e.KeyChar == '')
{
e.Handled = false; //Do not reject the input
}
else
{
e.Handled = true; //Reject the input
}
}