本文共 1232 字,大约阅读时间需要 4 分钟。
[TOC]
前一段时间帮公司开发的一套自定义表达式转sql
语句的引擎,对于比较规范的表达式处理,大量使用到了正则表达式做匹配,所以这里记录一下常用的方法,因为实际上方法很多,但是这里记录的只是自己常用到的。
这里以下面的字符串为例:
[{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();}
即可完成处理。
有下面的一个自定义布尔表达式:
(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 2scala> baseBoolExpression = baseBoolExpression.replaceAll("(\\d+)", "#DELIMITED#$0");baseBoolExpression: String = (#DELIMITED#1 OR #DELIMITED#3) AND #DELIMITED#2scala> baseBoolExpressionres68: String = (#DELIMITED#1 OR #DELIMITED#3) AND #DELIMITED#2
转载于:https://blog.51cto.com/xpleaf/2293804