EAS BOS:判断字符串是否为数字的方法的几种方法

用JAVA自带的函数
    public static boolean isNumericZidai(String str) {
        for (int i = 0; i < str.length(); i++) {
            System.out.println(str.charAt(i));
            if (!Character.isDigit(str.charAt(i))) {
                return false;
            }
        }
        return true;
    }

其中Character.isDigit方法:确定或判断指定字符是否是一个数字。

测试方法:

    public static void main(String[] args) {
        double aa = -19162431.1254;
        String a = "-19162431.1254";
        String b = "-19162431a1254";
        String c = "中文";
        System.out.println(isNumericzidai(Double.toString(aa)));
        System.out.println(isNumericzidai(a));
        System.out.println(isNumericzidai(b));
        System.out.println(isNumericzidai(c));
    }

结果显示:

false
false
false
false

这种方法显然不能判断 负数。

用正则表达式
    public static boolean isNumericzidai(String str) {
        Pattern pattern = Pattern.compile("-?[0-9]+.?[0-9]+");
        Matcher isNum = pattern.matcher(str);
        if (!isNum.matches()) {
            return false;
        }
        return true;
    }

网上给出的最好的方法,可惜还是错误;首先正则表达式-?[0-9]+.?[0-9]+这里就错误
网上说:可匹配所有数字。
比如:

        double aa = -19162431.1254;
        String a = "-19162431.1254";
        String b = "-19162431a1254";
        String c = "中文";
        System.out.println(isNumericzidai(Double.toString(aa)));
        System.out.println(isNumericzidai(a));
        System.out.println(isNumericzidai(b));
        System.out.println(isNumericzidai(c));

结果

false
true
true
false

正确的正则表达式是:-?[0-9]+\\.?[0-9]*,点号.,是匹配任意字符,需要进行转义。

注意:有一个错误,之前的正则表达式是这么写的:
-?[0-9]+\\.?[0-9]+,这种正则表达式在匹配0-9的正负数时,会出错,这是因为该表达式最后是+,表示的是匹配前一个字符1次或无限次。
也就是说在匹配一位的时候,会出现错误。所以改为*,表示匹配前一位字符0次或无限次。

System.out.println(isNumeric("9"));

结果为

true

于是我们改成:

    public static boolean isNumericzidai(String str) {
        Pattern pattern = Pattern.compile("-?[0-9]+\\.?[0-9]*");
        Matcher isNum = pattern.matcher(str);
        if (!isNum.matches()) {
            return false;
        }
        return true;
    }

执行上面代码结果:

false
true
false
false

可是为什么double aa = -19162431.1254;没有匹配为true呢?
原来当数字位数很长时,系统会自动转为科学计数法。所以aa=-1.91624311254E7.
所以我们需要使用java专门用于商业精度计数的类 BigDecimal.
我们需要new BigDecimal(str),但是呢,如果str为中文,会报异常。所以我用try catch捕捉异常。

正确的通用代码(传入包含中文、负数、位数很长的数字的字符串也能正常匹配):

    /**
     * 匹配是否为数字
     * @param str 可能为中文,也可能是-19162431.1254,不使用BigDecimal的话,变成-1.91624311254E7
     * @return
     */
    public static boolean isNumeric(String str) {
        // 该正则表达式可以匹配所有的数字 包括负数
        Pattern pattern = Pattern.compile("-?[0-9]+(\\.[0-9]+)?");
        String bigStr;
        try {
            bigStr = new BigDecimal(str).toString();
        } catch (Exception e) {
            return false;//异常 说明包含非数字。
        }

        Matcher isNum = pattern.matcher(bigStr); // matcher是全匹配
        if (!isNum.matches()) {
            return false;
        }
        return true;
    }
 

新思路

public static boolean isNumeric(String str) {
        String bigStr;
        try {
            bigStr = new BigDecimal(str).toString();
        } catch (Exception e) {
            return false;//异常 说明包含非数字。
        }
        return true;
    }
 

如果是数字,创建new BigDecimal()时肯定不会报错,那就可以直接返回true啦!
 

-?[0-9]+\\.?[0-9]*这个表达式在匹配字符串1.、222.时,确实会出现问题。
改为:-?[0-9]+(\\.[0-9]+)?。
测试后,确实是可以的!

org.apache.commons.lang3.StringUtils中的isNumeric,依旧不能判断负数、带小数点的数字。
第三方org.apache.commons.lang3包,是个好东西,但是也有很多bug的,用的时候多测测。

总结
肯定是使用第二种正则表达式计算啦!正则表达式用对地方啦,就不慢!
动不动就说正则太慢的人,是玩不6正则表达式的!


可以不使用正则,直接通过是否有异常来判断 
感觉可行(因为没有实战过,只是简单的测试了下!)


如果依然要使用正则表达式的话,目前正确的是:-?[0-9]+(\\.[0-9]+)?。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值