日期:2014-05-20  浏览次数:20736 次

问一个简单的正则问题
Java code

    public static void main(String[] args) {
        boolean b = isNumeric("aaaaaaabbbbbbbbbb[1]");
        System.out.println(b);
    }
    
    public static boolean isNumeric(String str){ 
        Pattern pattern = Pattern.compile("aaaaaaabbbbbbbbbb[0-9]*"); 
        return pattern.matcher(str).matches();    
    } 





我有一个字符串 "aaaaaaabbbbbbbbbb[1]" ,[]里的数字不一定就是1, 但是只能是1位数,我这么写为什么返回false啊???

------解决方案--------------------
aaaaaaabbbbbbbbbb\\[[0-9]\\]*
------解决方案--------------------
正则 改成 aaaaaaabbbbbbbbbb\[[0-9]\]*
或 aaaaaaabbbbbbbbbb\[\d\]*

需要匹配字符串中的中括号,需要把正则中的中括号转义
------解决方案--------------------
[0-9]*好像是表示0-9之間的數出現0次或多次,我覺著應該是[0-9]+,不知道對不對...
------解决方案--------------------
LZ,你是想匹配
aaaaaaabbbbbbbbbb[1],
aaaaaaabbbbbbbbbb[2],
aaaaaaabbbbbbbbbb[3]
这样的?

Pattern pattern = Pattern.compile("aaaaaaabbbbbbbbbb\\[\\d\\]");
Matcher m = pattern.matcher("aaaaaaabbbbbbbbbb[1]");
System.out.println(m.matches());