这篇文章主要讲解了“Java中Pattern.compile函数的用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中Pattern.compile函数的用法”吧!
Java Pattern.compile函数的使用
Pattern类的compile()方法还有另一个版本:
flag来自以下Pattern类中的常量:
我们可以通过“或”( | )操作组合多个标记的功能
使用Pattern.COMMENTS(?x)的例子:
Pattern.compile函数的相关解释
flag的取值范围如下:
除了Pattern Pattern.compile(String regex),
Pattern Pattern.complie(String regex,int flag),它接受一个标记参数flag,以调整匹配的行为。
在这些标记中 Pattern.CASE_INSENSITIVE(?i) ,Pattern.MULTLINE(?m),==Pattern.COMMENTS(?x)==中特别有用。
使用示例如下:
import java.util.regex.Matcher; import java.util.regex.Pattern; public class ReFlags { public static void main(String[] args) { Pattern p=Pattern.compile("^java",Pattern.CASE_INSENSITIVE|Pattern.MULTILINE); /* * 使用Pattern.CASE_INSENSITIVE(大小写不敏感的匹配)和Pattern.MULTILINE(多行模式)标记,忽略大小写地匹配所有以java开头的行 */ Matcher m=p.matcher("java has regex\nJava has regex\n" + "JAVA has pretty good regular expression\n" + "Regular expressions are in JavA"); while (m.find()) { System.out.println(m.group());//输出已匹配的部分 } } }
输出结果:
java
Java
JAVA
import java.util.regex.Matcher; import java.util.regex.Pattern; public class ReFlags_Comments { public static void main(String[] args) { /* * 不使用Pattern.COMMENTS(不启动注释) */ String s="123"; Pattern p1=Pattern.compile(" (\\d+)+#test comments"); Matcher m1=p1.matcher(s); System.out.println(m1.matches());//false /* * 正则表达式中使用启动注释的标记 */ Pattern p2=Pattern.compile("(?x) (\\d+)+#test comments"); Matcher m2=p2.matcher(s); System.out.println(m2.matches());//true /* * 参数中使用Pattern.COMMENTS以启动注释 */ Pattern p3=Pattern.compile(" (\\d+)+#test comments",Pattern.COMMENTS); Matcher m3=p3.matcher(s); System.out.println(m3.matches());//true } }
运行结果:
false
true
true
Pattern.compile函数:
Pattern Pattern.compile(String regex, int 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'才被认作一行的中止,并且与'.','^',以及'$'进行匹配。
免责声明:本站发布的内容(图片、视频和文字)以原创、来自互联网转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系QQ:712375056 进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
Copyright © 2009-2021 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 珠海市特网科技有限公司 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站