Java开发常用正则表达式处理案例总结
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java开发常用正则表达式处理案例总结相关的知识,希望对你有一定的参考价值。
[TOC]
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
以上是关于Java开发常用正则表达式处理案例总结的主要内容,如果未能解决你的问题,请参考以下文章