Java开发常用正则表达式处理案例总结
2021-05-19 21:28
标签:总结 公司 现在 expr date 正则表达式 自己 mit express 前一段时间帮公司开发的一套自定义表达式转 这里以下面的字符串为例: 这里希望用正则表达式处理的方式拿到 首先编写正则表达式如下: 正则处理: 即可完成处理。 有下面的一个自定义布尔表达式: 现在希望将数字替换为其它想要的字符串,同时也带上原来的数字,即上面的表达式处理之后如下: 处理方法如下: 可以在 Java开发常用正则表达式处理案例总结 标签:总结 公司 现在 expr date 正则表达式 自己 mit express 原文地址:http://blog.51cto.com/xpleaf/2293804
1 前言
sql
语句的引擎,对于比较规范的表达式处理,大量使用到了正则表达式做匹配,所以这里记录一下常用的方法,因为实际上方法很多,但是这里记录的只是自己常用到的。2 常用方法
2.1 案例1
[{EXP}, [1536206035, 1536547988]]
[{EXP}, [1536206035,)]
[{EXP}, (,1536206035]]
{EXP}
后面的内容,即上面的[1536206035, 1536547988]
、[1536206035,)
或(,1536206035]
。public static final String GET_EXP_DATE_RANGE = "^ *\\[ *\\{ *EXP *\\} *, *(.*) *\\]$ *"
Matcher matcher = Pattern.compile(DateRules.GET_EXP_DATE_RANGE).matcher(expression);
if(matcher.find()) {
String content = matcher.group(1).trim();
}
2.2 案例2
(1 OR 3) AND 2
(#DELIMITED#1 OR #DELIMITED#3) AND #DELIMITED#2
baseBoolExpression = baseBoolExpression.replaceAll("(\\d+)", "#DELIMITED#$0");
Scala
的交互式解析器中测试一下(Scala
的String
就是java.lang.string
):scala> var baseBoolExpression:String = "(1 OR 3) AND 2"
baseBoolExpression: String = (1 OR 3) AND 2
scala> baseBoolExpression = baseBoolExpression.replaceAll("(\\d+)", "#DELIMITED#$0");
baseBoolExpression: String = (#DELIMITED#1 OR #DELIMITED#3) AND #DELIMITED#2
scala> baseBoolExpression
res68: String = (#DELIMITED#1 OR #DELIMITED#3) AND #DELIMITED#2