Pattern.compile函数提取字符串中指定的字符(推荐)
梦幻通灵 人气:0最近有个需求是要提取一段字符串中特定范围内的内容,查找资料后,使用的是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:此种模式下,表达式’.‘可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式’.'不匹配行的结束符。
项目中程序例子
在项目中运用的 flag 的 CASE_INSENSITIVE参数,此处主要是截取中括号中的内容,截取的实现代码如下:
// 引入包 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); }
运行结果如下图所示。
本程序中定义的规则表达式主要提取四个括号内的内容,以 \\ 符号为开始,后面跟截取的符号,w表示匹配的字符。按照此规则就可以提取出来相应的参数:tableName 表示提取的表名,filed 表示提取的字段名。
参考下面教程:
Pattern.compile函数的相关解释
Pattern.compile函数:Pattern Pattern.compile(String regex, int flag)
flag的取值范围如下:
Pattern.CANON_EQ:当且仅当两个字符的"正规分解(canonical decomposition)"都完全相同的情况下,才认定匹配。比如用了这个标志之后,表达 式"a\u030A"会匹配"?"。默认情况下,不考虑"规范相等性(canonical equivalence)"。
Pattern.CASE_INSENSITIVE: 默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。这个标志能让表达式忽略大小写进行匹配。要想对Unicode字符进行大小不明感的匹 配,只要将UNICODE_CASE与这个标志合起来就行了。
Pattern.COMMENTS: 在这种模式下,匹配时会忽略(正则表达式里的)空格字符(不是指表达式里的"\\s",而是指表达式里的空格,tab,回车之类)。注释从#开始,一直到这行结束。可以通过嵌入式的标志来启用Unix行模式。
Pattern.DOTALL: 在这种模式下,表达式'.'可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式'.'不匹配行的结束符。
Pattern.MULTILINE: 在这种模式下,'^'和'$'分别匹配一行的开始和结束。此外,'^'仍然匹配字符串的开始,'$'也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的开始和结束。
Pattern.UNICODE_CASE: 在这个模式下,如果你还启用了CASE_INSENSITIVE标志,那么它会对Unicode字符进行大小写不明感的匹配。默认情况下,大小写不敏感的匹配只适用于US-ASCII字符集。
Pattern.UNIX_LINES(?d) 在这个模式下,只有'\n'才被认作一行的中止,并且与'.','^',以及'$'进行匹配。
加载全部内容