c#判断string是否为数字
有人提议用int.Parse( string )的方法,然后通过捕获异常来判断返回的值。更好的方法是用正则表达式:
public int IsNumeric( string str)
{
int i;
if (str != null && Regex.IsMatch(str, @" ^\d+$ " ))
i = int .Parse(str);
else
i = - 1 ;
return i;
}
这应该是个好办法。不过如果要提出更高的要求,例如不仅要判断字符串是否全为数字,还要在判断后,要求将其进行转换。那么上述函数就有缺陷,因为在上面的正则表达式中无法判断‘ - ’符号。因此上面的函数只能转换非负数。尤有甚者,要求转换的不仅是整数,还包括浮点数,尤其是科学计数法的字符串,例如: string s = " -3.14159E+10 "
这里面的 ' E ' 、 ' . ' 、 ' + ' 等字符,都是比较特殊的,而且还要求它们出现的位置要符合浮点数或科学计数方法的规定。那么就不能使用正则表达式了,至少很麻烦(我是这样认为的,或许有好的方法)。问题还是回到最初的解决方案,就是使用Parse()方法和捕获异常。以下是实现此功能的方法:
public bool IsNumeric( string s, out double result)
{
bool bReturn = true ;
try
{
result = double .Parse(s);
}
catch
{
result = 0 ;
bReturn = false ;
}
return bReturn;
}
例如调用:
string s1 = " abc " ;
string s2 = " -3.14159E+10 " ;
double d1,d2;
bool ty1 = IsNumeric(s1, out d1);
bool ty2 = IsNumeric(s2, out d2);
结果:
ty1 = false ;d1 = 0 ;
ty2 = true ;d2 = 31415900000
说明:因为涉及到浮点数,就不能使用 - 1来做为出现错误的返回值,如前面的例子。也就是说本方法有两个返回值,一个是判断转换是否成功,为bool型;另一个是转换成功后的浮点数值。我用out来解决该问题。
本方法仍然适合整型,只需对返回值进行强制转换即可。
在VB中原有一个 inumeric函数来判断
到了C#.net中却没有了。
网上很多用的是try{}来做,这一方法不是不行,但是,由于这个是用catch一个错误来实现,会导致数据比较慢(个人尝试过,觉得慢多了),所以,以下方法使用的是一个正则表达式得来的
// 判断是否为正整数
public static bool IsInt( string inString)
{
Regex regex = new Regex( " ^[0-9]*[1-9][0-9]*$ " );
return regex.IsMatch(inString.Trim());
}
用这个方法除了判断是否为数字还可以判断其他的,比如判断E - mail格式是否正确等等,只要正则表达式支持的,这里都支持,只需要把正则表达式替换了代码中蓝色的部分即可,关于正则不会的,可以在我BLOG里找,有一篇正则的介绍,相当全面!
几个正则表达式的例子:
" ^\\d+$ " // 非负整数(正整数 + 0)
" ^[0-9]*[1-9][0-9]*$ " // 正整数
" ^((-\\d+)|(0+))$ " // 非正整数(负整数 + 0)
" ^-[0-9]*[1-9][0-9]*$ " // 负整数
" ^-?\\d+$ " // 整数
" ^\\d+(\\.\\d+)?$ " // 非负浮点数(正浮点数 + 0)
" ^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$ "
// 正浮点数
" ^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$ " // 非正浮点数(负浮点数 + 0)
" ^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ "
// 负浮点数
" ^(-?\\d+)(\\.\\d+)?$ " // 浮点数
" ^[A-Za-z]+$ " // 由26个英文字母组成的字符串
" ^[A-Z]+$ " // 由26个英文字母的大写组成的字符串
" ^[a-z]+$ " // 由26个英文字母的小写组成的字符串
" ^[A-Za-z0-9]+$ " // 由数字和26个英文字母组成的字符串
" ^\\w+$ " // 由数字、26个英文字母或者下划线组成的字符串
" ^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$ " // email地址
" ^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$ " // url
本文来自CSDN博客,转载:http: // blog.csdn.net/zhangchunwen/archive/2008/06/02/2503438.aspx
有人提议用int.Parse( string )的方法,然后通过捕获异常来判断返回的值。更好的方法是用正则表达式:
public int IsNumeric( string str)
{
int i;
if (str != null && Regex.IsMatch(str, @" ^\d+$ " ))
i = int .Parse(str);
else
i = - 1 ;
return i;
}
这应该是个好办法。不过如果要提出更高的要求,例如不仅要判断字符串是否全为数字,还要在判断后,要求将其进行转换。那么上述函数就有缺陷,因为在上面的正则表达式中无法判断‘ - ’符号。因此上面的函数只能转换非负数。尤有甚者,要求转换的不仅是整数,还包括浮点数,尤其是科学计数法的字符串,例如: string s = " -3.14159E+10 "
这里面的 ' E ' 、 ' . ' 、 ' + ' 等字符,都是比较特殊的,而且还要求它们出现的位置要符合浮点数或科学计数方法的规定。那么就不能使用正则表达式了,至少很麻烦(我是这样认为的,或许有好的方法)。问题还是回到最初的解决方案,就是使用Parse()方法和捕获异常。以下是实现此功能的方法:
public bool IsNumeric( string s, out double result)
{
bool bReturn = true ;
try
{
result = double .Parse(s);
}
catch
{
result = 0 ;
bReturn = false ;
}
return bReturn;
}
例如调用:
string s1 = " abc " ;
string s2 = " -3.14159E+10 " ;
double d1,d2;
bool ty1 = IsNumeric(s1, out d1);
bool ty2 = IsNumeric(s2, out d2);
结果:
ty1 = false ;d1 = 0 ;
ty2 = true ;d2 = 31415900000
说明:因为涉及到浮点数,就不能使用 - 1来做为出现错误的返回值,如前面的例子。也就是说本方法有两个返回值,一个是判断转换是否成功,为bool型;另一个是转换成功后的浮点数值。我用out来解决该问题。
本方法仍然适合整型,只需对返回值进行强制转换即可。
在VB中原有一个 inumeric函数来判断
到了C#.net中却没有了。
网上很多用的是try{}来做,这一方法不是不行,但是,由于这个是用catch一个错误来实现,会导致数据比较慢(个人尝试过,觉得慢多了),所以,以下方法使用的是一个正则表达式得来的
// 判断是否为正整数
public static bool IsInt( string inString)
{
Regex regex = new Regex( " ^[0-9]*[1-9][0-9]*$ " );
return regex.IsMatch(inString.Trim());
}
用这个方法除了判断是否为数字还可以判断其他的,比如判断E - mail格式是否正确等等,只要正则表达式支持的,这里都支持,只需要把正则表达式替换了代码中蓝色的部分即可,关于正则不会的,可以在我BLOG里找,有一篇正则的介绍,相当全面!
几个正则表达式的例子:
" ^\\d+$ " // 非负整数(正整数 + 0)
" ^[0-9]*[1-9][0-9]*$ " // 正整数
" ^((-\\d+)|(0+))$ " // 非正整数(负整数 + 0)
" ^-[0-9]*[1-9][0-9]*$ " // 负整数
" ^-?\\d+$ " // 整数
" ^\\d+(\\.\\d+)?$ " // 非负浮点数(正浮点数 + 0)
" ^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$ "
// 正浮点数
" ^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$ " // 非正浮点数(负浮点数 + 0)
" ^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ "
// 负浮点数
" ^(-?\\d+)(\\.\\d+)?$ " // 浮点数
" ^[A-Za-z]+$ " // 由26个英文字母组成的字符串
" ^[A-Z]+$ " // 由26个英文字母的大写组成的字符串
" ^[a-z]+$ " // 由26个英文字母的小写组成的字符串
" ^[A-Za-z0-9]+$ " // 由数字和26个英文字母组成的字符串
" ^\\w+$ " // 由数字、26个英文字母或者下划线组成的字符串
" ^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$ " // email地址
" ^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$ " // url
本文来自CSDN博客,转载:http: // blog.csdn.net/zhangchunwen/archive/2008/06/02/2503438.aspx