当前位置: 代码迷 >> J2SE >> 问一个简单的正则有关问题
  详细解决方案

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

热度:3951   发布时间:2013-02-25 00:00:00.0
问一个简单的正则问题
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());
  相关解决方案