因实际工作需要,需要把一个形如 [["0","0","","","",""],[["",""],["",""]],[]]的字符串清空变成[[],[[],[]],[]]。
实现起来 首先需要把 "0"替换为空字符串,再把""替换为空字符串
此时 字符串变为[[,,,,,],[[,],[,]],[]]
在想起来正则之前,大概会采用先以]拆分字符串,再根据逗号拆分,再怎样怎样,感觉就很麻烦,我就没接着想。
正则的好处就体现出来了,楼主是个正则痴迷者,就像之前就说的那样 有了正则,只要三句话,完全能搞定!
代码如下:
private String clearStr(String valStr)
{
valStr = valStr.replace("\"0\"", "").replace("\"\"", "");
//[[,,,,,],[[,],[,]],[]]
Pattern p = Pattern.compile("\\[,+]");
Matcher m = p.matcher(valStr);
valStr = m.replaceAll("[]");
return valStr;
}
正则说明:需要匹配的格式是在[]之间,有且只有1个以上的逗号。逗号不属于正则中的特殊字符(?*.+^$[ 属于 别的暂时没想起来,不知道=算不算),[属于正则中的特殊符号,需要转译,+表示至少存在一个
mathcer:符号正则规则的 统一替换为[]
这样完全不需要考虑[]之间有多少个逗号,只要三行 解决一切的正则!!
————————————————————————————————————————————————————————————————————————
然后我又发现,既然正则就能替换了,我第一行完全多余啊,修改代码如下:
private String clearStr(String valStr)
{
Pattern p = Pattern.compile("\\[(\"0\",|\"\",)*(\"0\"|\"\")]");
Matcher m = p.matcher(valStr);
valStr = m.replaceAll("[]");
return valStr;
}
这比以前功能更好了有木有,以前那个会导致[,,"100",,,]这么尴尬的变形,虽然也不咋影响使用,但是不好看呀,正则改版之后,哇哦
不过我的正则水准有待提高啊 我觉得规则好像写复杂了,反正能用