最近有个需求是要提取一段字符串中特定范围内的内容,查找资料后,使用的是Java中的Pattern.compile函数来实现对指定字符串的截取。记录下来查找的知识和应用,方便以后的查看。
Pattern.compile函数语法
// Pattern.compile函数语法
Pattern Pattern.compile(String regex, int flag)
知识学习
Pattern.compile函数中两个参数
- regex 表示定义的规则
- 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)));