判断一个字符串是否可以转换为数字(包括小数及正负),写一个正则表达式判断:
package com.test;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test1 {
public static boolean regex(String content) {
String pattern = "^[\\+\\-]?[\\d]+(\\.[\\d]+)?$";
Pattern r = Pattern.compile(pattern);
Matcher m = r.matcher(content);
return m.matches();
}
public static void main(String[] args) {
String[] tests = new String[] {
"0", "0.4", "2.888888",
"+0.4", "-0.4", "-2.88888",
"4nm", "-4nm", "+4nm", "+4.nm", "-4.nm",
"4年4个省市", "+4年4个省市", "-4年4个省市",
"4.4个省市", "+4.4个省市", "-4.4个省市"
}; //部分测试用例
for (String string : tests) {
System.out.println(string + " : " + regex(string));
}
}
}
运行截图:

本文提供了一个用于判断字符串是否能转换为数字(包括小数和正负数)的正则表达式,并通过Java实现进行验证。文章包含了多个测试用例以展示正则表达式的正确性和有效性。

1439

被折叠的 条评论
为什么被折叠?



