Java开发常用正则表达式处理案例总结

2021-05-19 21:28

阅读:347

标签:总结   公司   现在   expr   date   正则表达式   自己   mit   express   

[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的交互式解析器中测试一下(ScalaString就是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开发常用正则表达式处理案例总结

标签:总结   公司   现在   expr   date   正则表达式   自己   mit   express   

原文地址:http://blog.51cto.com/xpleaf/2293804


评论


亲,登录后才可以留言!