读书人

问一个简单的正则有关问题

发布时间: 2012-10-23 12:12:22 作者: rapoo

问一个简单的正则问题

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());

读书人网 >J2SE开发

热点推荐