Java之Pattern.compile函數(shù)用法詳解
除了Pattern Pattern.compile(String regex),
Pattern類的compile()方法還有另一個版本:
Pattern Pattern.complie(String regex,int flag),它接受一個標記參數(shù)flag,以調(diào)整匹配的行為。
flag來自以下Pattern類中的常量:
編譯標記 | 效果 |
---|---|
Pattern.CANON_EQ | 兩個字符當且僅當它們的完全規(guī)范分解相匹配時,就認為它們是匹配的,例如,如果我們指定這個標記,表達式a\u030A就會匹配字符串?。在默認的情況下,匹配不考慮規(guī)范的等價性 |
Pattern.CASE_INSENSITIVE(?i) | 默認情況下,大小寫不敏感的匹配假定只有US-ASCII字符集中的字符才能進行。這個標記允許模式匹配不必考慮大小寫(大寫或小寫)。通過指定UNICODE_CASE標記及結(jié)合此標記,基于Unicode的大小寫不敏感的匹配就可以開啟了,也可以使用嵌入的標記表達式?i開啟,下同 |
Pattern.COMMENTS(?x) | 在這種模式下,表達式中的空格(不是指\s,單純指空格)將被忽略掉,并且以#開始直到行末的注釋也會被忽略掉。通過嵌入的標記表達式也可以開啟Unix的行模式 |
Pattern.DOTALL(?s) | 在dotall模式中,表達式“.”匹配所有字符,包括行終結(jié)符。默認情況下,“.”表達式不匹配行終結(jié)符 |
Pattern.MULTLINE(?m) | 在多行模式下,表達式^和$分別匹配一行或輸入字符串的開始和結(jié)束。默認情況下,這些表達式僅匹配輸入的完整字符串的開始和結(jié)束 |
Pattern.UNICODE_CASE(?u) | 當指定這個標記,并且開啟CASE_INSENSITIVE時,大小寫不敏感的匹配將按照與Unicode標準相一致的方式進行。默認情況下,大小寫不敏感的匹配假定只能在US-ASCII字符集中的字符才能進行 |
Pattern.UNIX_LINES(?d) | 在這種模式下,在.、^和$行為中,只識別行終結(jié)符\n |
在這些標記中 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());//輸出已匹配的部分 } } }
輸出結(jié)果:
java Java JAVA
使用Pattern.COMMENTS(?x)的例子:
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 /* * 參數(shù)中使用Pattern.COMMENTS以啟動注釋 */ Pattern p3=Pattern.compile(" (\\d+)+#test comments",Pattern.COMMENTS); Matcher m3=p3.matcher(s); System.out.println(m3.matches());//true } }
運行結(jié)果:
false true true
到此這篇關于Java之Pattern.compile函數(shù)用法詳解的文章就介紹到這了,更多相關Java之Pattern.compile函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解如何在Spring Boot啟動后執(zhí)行指定代碼
這篇文章主要介紹了在Spring Boot啟動后執(zhí)行指定代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06SpringCloud之Zuul網(wǎng)關原理及其配置講解
這篇文章主要介紹了SpringCloud之Zuul網(wǎng)關原理及其配置講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03java map轉(zhuǎn)Multipart/form-data類型body實例
這篇文章主要介紹了java map轉(zhuǎn)Multipart/form-data類型body實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05spring mvc中注解@ModelAttribute的妙用分享
這篇文章主要給大家介紹了關于spring mvc中注解@ModelAttribute妙用的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Android具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-09-09Java封裝數(shù)組之動態(tài)數(shù)組實現(xiàn)方法詳解
這篇文章主要介紹了Java封裝數(shù)組之動態(tài)數(shù)組實現(xiàn)方法,結(jié)合實例形式詳細分析了java動態(tài)數(shù)組的實現(xiàn)原理、操作步驟與相關注意事項,需要的朋友可以參考下2020-03-03springboot集成junit編寫單元測試實戰(zhàn)
在做單元測試時,代碼覆蓋率常常被拿來作為衡量測試好壞的指標,本文主要介紹了springboot集成junit編寫單元測試實戰(zhàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02