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的交互式解析器中测试一下(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开发常用正则表达式处理案例总结的主要内容,如果未能解决你的问题,请参考以下文章

常用正则表达式总结

正则表达式常用语法

常用正则表达式合集,这一篇就够了!!(含完整案例,建议收藏)

常用正则表达式 总结

常用正则表达式 总结

为了帮女同事摸鱼,我帮她总结了这份“常用正则表达式大全!”开发必备