// 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); }
文章评论