首页 > 技术文章 > 一个$符,差点把我搞死了

haoxiu1004 2017-10-26 16:03 原文

说明:在我使用update进行数据修改的时候,破天荒的有个字段的数据开头是$符的,这就尴尬了,jdk竟然把它当做是正则表达式来处理的,所以报错的结果是:java.lang.IndexOutOfBoundsException: No group 2

   查了资料,非常感谢@单眼皮的猪 提供的解决方法:

 

 

在使用String.replaceAll(regex,replacement)方法时,当replacement出现反斜杠\或美元符号$时会出现java.lang.IndexOutOfBoundsException No group的异常,查看api文档时说是可以用java.util.regex.Matcher.quoteReplacement(String s)先过滤,但是此方法是1.5才出现的

如果是1.4
手写以下方法即可实现

    1.   
    2.     public static String quoteReplacement(String s) {  
    3.         if ((s.indexOf('\\') == -1) && (s.indexOf('$') == -1))  
    4.             return s;  
    5.         StringBuffer sb = new StringBuffer();  
    6.         for (int i=0; i<s.length(); i++) {  
    7.             char c = s.charAt(i);  
    8.             if (c == '\\') {  
    9.                 sb.append('\\'); sb.append('\\');  
    10.             } else if (c == '$') {  
    11.                 sb.append('\\'); sb.append('$');  
    12.             } else {  
    13.                 sb.append(c);  
    14.             }  
    15.         }  
    16.         return sb.toString();  
    17.     }  
    18. 当然了我用了一个更简单粗暴的方法,就是将数据库中的$符,直接删除

推荐阅读