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:此种模式下,表达式’.‘可以匹配任意字符,包括表示一行的结束符。默认情况下,表达式’.'不匹配行的结束符。
项目中程序例子
在项目中运用的 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'才被认作一行的中止,并且与'.','^',以及'$'进行匹配。
到此这篇关于Pattern.compile函数提取字符串中指定的字符的文章就介绍到这了,更多相关Pattern.compile函数提取字符串指定字符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!