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:此种模式下,表达式’.‘可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式’.'不匹配行的结束符。

项目中程序例子

     在项目中运用的 flagCASE_INSENSITIVE参数,此处主要是截取中括号中的内容,截取的实现代码如下:

//需要截取的字符串
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);
	//截取的开始位置 [
	String tableJoin1 = matcher.group(1);
	//截取出来的表名 user
	String tableName = matcher.group(2);
	//截取出来的字段名 name
	String filed = matcher.group(3);
	//截取的结束位置 ]
	String tableJoin4 = matcher.group(4);
}

     本程序中定义的规则表达式主要提取四个括号内的内容,以\\符号为开始,后面跟截取的符号,w表示匹配的字符。按照此规则就可以提取出来相应的参数:tableName 表示提取的表名,filed 表示提取的字段名。

博客参考:

【1】https://blog.csdn.net/xinjie1224/article/details/41209017

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页