代码技巧:Pattern.compile函数提取字符串中指定的字符(正则使用)

最近有个需求是要提取一段字符串中特定范围内的内容,查找资料后,使用的是Java中的Pattern.compile函数来实现对指定字符串的截取。记录下来查找的知识和应用,方便以后的查看。

Pattern.compile函数语法

// Pattern.compile函数语法
Pattern Pattern.compile(String regex, int flag)

知识学习
Pattern.compile函数中两个参数

  1. regex 表示定义的规则
  2. flag 表示设置的参数类型,主要包含以下几种情况:
    (1)Pattern.CASE_INSENSITIVE(?i) 默认情况下,大小写不明感的匹配只适用于US-ASCII字符集。让表达式忽略大小写进行匹配。
    (2)Pattern.COMMENTS(?x) 此种模式下,匹配时会忽略表达式中空格字符(表达式里的空格,tab,回车)。注释从#开始,一直到这行结束。
    (3)Pattern.UNIX_LINES(?d) 此种模式下,只有’\n’才被认作一行的中止,并且与’.’,’^’,以及’$’进行匹配。
    (4)Pattern.MULTILINE(?m) 此种模式下,上箭头和单引号分别匹配一行的开始和结束。此外,’^‘仍然匹配字符串的开始,’’也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。
    (5)Pattern.DOTALL:此种模式下,表达式’.‘可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式’.'不匹配行的结束符。

实战

// 引入包
import java.util.regex.Matcher;
import java.util.regex.Pattern;

//需要截取的字符串
String splitStr = "[user:name] = select name from user";
// 定义规则
String pattern = "(\\[+)(\\w+)\\:(\\w+)(\\]+)";
//Pattern.compile函数
Matcher matcher = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE).matcher(splitStr);
while (matcher.find()) { //表示往下遍历
	//截取出来的字符串 [user:name]
	String allcon = matcher.group(0);
	System.out.println("allcon匹配的结果为"+allcon);
	//截取的开始位置 [
	String tableJoin1 = matcher.group(1);
	System.out.println("tableJoin1匹配的结果为"+tableJoin1);
	//截取出来的表名 user
	String tableName = matcher.group(2);
	System.out.println("tableName匹配的结果为"+tableName);
	//截取出来的字段名 name
	String filed = matcher.group(3);
	System.out.println("filed匹配的结果为"+filed);
	//截取的结束位置 ]
	String tableJoin4 = matcher.group(4);
	System.out.println("tableJoin4匹配的结果为"+tableJoin4);
}
query.addCriteria(Criteria.where("name").regex(Pattern.compile("^.*" + dataBaseType + 
".*$", Pattern.CASE_INSENSITIVE)));
  • 2
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值