需求场景:
今天在处理SQL语句的时候,由于数据库中存的格式是VARCHAR2型的,这就需要对SQL语句中WHERE条件后边的带数字的字符串加上单引号,对于字符串的处理,首先想到的就是正则表达式,对正则表达式,虽然有一些了解,但是也谈上很熟练,百度了一番(正常网络也就那个几个无奈的搜索引擎使用啦),发现替换,基本上属于固定替换,就是把某一类符合正则标准的,全部替换为一个固定的字符串,比如说,错别字的处理啊,还是比较好用的,这个在程序中也有实现,很easy。但是,我需要的是多个,且是动态替换的,最基本的就是保留原来的匹配出来的串,然后再在首尾加上些东西。我大致搜索了一下,没发现一个满足我要求的。好吧,那就自己动手,丰衣足食吧。
解决方案:
简单说说我的思路,我是将字符串,进行了两次分割,一次匹配出满足正则表达式的串,一次匹配出不满足正则的串,这样他们总是相间的出现的,这样我就可以随意的操作匹配或者非匹配的串,然后再把他们何到一起。
上源码:
package com.util.regex; import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern; public class RegexUtil {
private String strSource="";
private String StrRe=""; public String getStrSource() {
return strSource;
}
public void setStrSource(String strSource) {
this.strSource = strSource;
}
public String getStrRe() {
return StrRe;
}
public void setStrRe(String strRe) {
StrRe = strRe;
}
public String flixedReplace(String rep){
return this.strSource.replaceAll(this.StrRe, rep);
}
/**
* <li>Description:</li>
* <li>Date:</li>
* <li>Modify:</li>
* <li>Version: 1.0</li>
* @author Administrator
* @param form
* @param last
* @return String
*/
@SuppressWarnings("unchecked")
public String splitReplace(String form,String last){
String ss[]=this.getStrSource().split(this.getStrRe());
Pattern p = Pattern.compile(this.getStrRe());
Matcher m = p.matcher(this.getStrSource());
LinkedHashMap<Integer, String> map=new LinkedHashMap<Integer,String>();
int i=0;
while(m.find()){
map.put(i, form+m.group()+last);
i++;
}
Iterator<?> iter=map.entrySet().iterator();
StringBuffer tarStr=new StringBuffer();
for(int j=0;j<ss.length;j++){
if(!this.getStrSource().isEmpty()&&(!Character.isDigit(this.getStrSource().charAt(0))||j!=0)){
tarStr.append(ss[j]);
}
if(iter.hasNext()){
Map.Entry<Integer, String> entry=(Map.Entry<Integer, String>)iter.next();
if(entry.getKey()==j){
tarStr.append(entry.getValue());
}
}
}
return tarStr.toString();
} public static void main(String[] args) {
RegexUtil re=new RegexUtil();
re.setStrSource(" 2132 3213 adsd 12321 asdfsa dsdf 12 1313adfaf231321dfafda1141dfaffafdf");
re.setStrRe("\\d+");
System.out.println(re.flixedReplace("hello"));
System.out.println(re.splitReplace("'", "'"));
// System.out.println(re.getStrSource().replaceAll("(\\w+)(\\d+)", "$1'$2"));
}
}