小編給大家分享一下Java正則表達(dá)式怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的渝中網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!什么是正則表達(dá)式?
正則表達(dá)式定義了字符串的模式。正則表達(dá)式可以用來(lái)搜索、編輯或處理文本。正則表達(dá)式并不僅限于某一種語(yǔ)言,但是在每種語(yǔ)言中有細(xì)微的差別。Java正則表達(dá)式和Perl的是最為相似的。
Java正則表達(dá)式的類在 java.util.regex 包中,包括三個(gè)類:Pattern,Matcher和PatternSyntaxException。
Pattern對(duì)象是正則表達(dá)式的已編譯版本。他沒(méi)有任何公共構(gòu)造器,我們通過(guò)傳遞一個(gè)正則表達(dá)式參數(shù)給公共靜態(tài)方法 compile 來(lái)創(chuàng)建一個(gè)pattern對(duì)象。
Matcher是用來(lái)匹配輸入字符串和創(chuàng)建的 pattern 對(duì)象的正則引擎對(duì)象。這個(gè)類沒(méi)有任何公共構(gòu)造器,我們用patten對(duì)象的matcher方法,使用輸入字符串作為參數(shù)來(lái)獲得一個(gè)Matcher對(duì)象。然后使用matches方法,通過(guò)返回的布爾值判斷輸入字符串是否與正則匹配。
如果正則表達(dá)式語(yǔ)法不正確將拋出PatternSyntaxException異常。
讓我們?cè)谝粋€(gè)簡(jiǎn)單的例子里看看這些類是怎么用的吧
package com.journaldev.util; import java.util.regex.Matcher; import java.util.regex.Pattern; public class RegexExamples { public static void main(String[] args) { // using pattern with flags Pattern pattern = Pattern.compile("ab", Pattern.CASE_INSENSITIVE); Matcher matcher = pattern.matcher("ABcabdAb"); // using Matcher find(), group(), start() and end() methods while (matcher.find()) { System.out.println("Found the text \"" + matcher.group() + "\" starting at " + matcher.start() + " index and ending at index " + matcher.end()); } // using Pattern split() method pattern = Pattern.compile("\\W"); String[] words = pattern.split("one@two#three:four$five"); for (String s : words) { System.out.println("Split using Pattern.split(): " + s); } // using Matcher.replaceFirst() and replaceAll() methods pattern = Pattern.compile("1*2"); matcher = pattern.matcher("11234512678"); System.out.println("Using replaceAll: " + matcher.replaceAll("_")); System.out.println("Using replaceFirst: " + matcher.replaceFirst("_")); } }
既然正則表達(dá)式總是和字符串有關(guān), Java 1.4對(duì)String類進(jìn)行了擴(kuò)展,提供了一個(gè)matches方法來(lái)匹配pattern。在方法內(nèi)部使用Pattern和Matcher類來(lái)處理這些東西,但顯然這樣減少了代碼的行數(shù)。
Pattern類同樣有matches方法,可以讓正則和作為參數(shù)輸入的字符串匹配,輸出布爾值結(jié)果。
下述的代碼可以將輸入字符串和正則表達(dá)式進(jìn)行匹配。
String str = "bbb"; System.out.println("Using String matches method: "+str.matches(".bb")); System.out.println("Using Pattern matches method: "+Pattern.matches(".bb", str));
所以如果你的需要僅僅是檢查輸入字符串是否和pattern匹配,你可以通過(guò)調(diào)用String的matches方法省下時(shí)間。只有當(dāng)你需要操作輸入字符串或者重用pattern的時(shí)候,你才需要使用Pattern和Matches類。
注意由正則定義的pattern是從左至右應(yīng)用的,一旦一個(gè)原字符在一次匹配中使用過(guò)了,將不會(huì)再次使用。
例如,正則“121”只會(huì)匹配兩次字符串“31212142121″,就像這樣“_121____121″。
正則表達(dá)式通用匹配符號(hào)
Java正則表達(dá)式元字符
有兩種方法可以在正則表達(dá)式中像一般字符一樣使用元字符。
在元字符前添加反斜杠(\)
將元字符置于\Q(開始引用)和\E(結(jié)束引用)間
正則表達(dá)式量詞
量詞指定了字符匹配的發(fā)生次數(shù)。
量詞可以和character classes和capturing group一起使用。
例如,[abc]+表示a,b或c出現(xiàn)一次或者多次。
(abc)+表示capturing group “abc”出現(xiàn)一次或多次。我們即將討論capturing group。
正則表達(dá)式capturing group
Capturing group是用來(lái)對(duì)付作為一個(gè)整體出現(xiàn)的多個(gè)字符。你可以通過(guò)使用()來(lái)建立一個(gè)group。輸入字符串中和capturing group相匹配的部分將保存在內(nèi)存里,并且可以通過(guò)使用Backreference調(diào)用。
你可以使用matcher.groupCount方法來(lái)獲得一個(gè)正則pattern中capturing groups的數(shù)目。例如((a)(bc))包含3個(gè)capturing groups; ((a)(bc)), (a) 和 (bc)。
你可以使用在正則表達(dá)式中使用Backreference,一個(gè)反斜杠(\)接要調(diào)用的group號(hào)碼。
Capturing groups和Backreferences可能很令人困惑,所以我們通過(guò)一個(gè)例子來(lái)理解。
System.out.println(Pattern.matches("(\\w\\d)\\1", "a2a2")); //true System.out.println(Pattern.matches("(\\w\\d)\\1", "a2b2")); //false System.out.println(Pattern.matches("(AB)(B\\d)\\2\\1", "ABB2B2AB")); //true System.out.println(Pattern.matches("(AB)(B\\d)\\2\\1", "ABB2B3AB")); //false
在第一個(gè)例子里,運(yùn)行的時(shí)候第一個(gè)capturing group是(\w\d),在和輸入字符串“a2a2″匹配的時(shí)候獲取“a2″并保存到內(nèi)存里。因此\1是”a2”的引用,并且返回true。基于相同的原因,第二行代碼打印false。
試著自己理解第三行和第四行代碼。:)
現(xiàn)在我們來(lái)看看Pattern和Matcher類中一些重要的方法。
我們可以創(chuàng)建一個(gè)帶有標(biāo)志的Pattern對(duì)象。例如Pattern.CASE_INSENSITIVE可以進(jìn)行大小寫不敏感的匹配。Pattern類同樣提供了和String類相似的split(String) 方法
Pattern類toString()方法返回被編譯成這個(gè)pattern的正則表達(dá)式字符串。
Matcher類有start()和end()索引方法,他們可以顯示從輸入字符串中匹配到的準(zhǔn)確位置。
Matcher類同樣提供了字符串操作方法replaceAll(String replacement)和replaceFirst(String replacement)。
現(xiàn)在我們?cè)谝粋€(gè)簡(jiǎn)單的java類中看看這些函數(shù)是怎么用的。
package com.journaldev.util; import java.util.regex.Matcher; import java.util.regex.Pattern; public class RegexExamples { public static void main(String[] args) { // using pattern with flags Pattern pattern = Pattern.compile("ab", Pattern.CASE_INSENSITIVE); Matcher matcher = pattern.matcher("ABcabdAb"); // using Matcher find(), group(), start() and end() methods while (matcher.find()) { System.out.println("Found the text \"" + matcher.group() + "\" starting at " + matcher.start() + " index and ending at index " + matcher.end()); } // using Pattern split() method pattern = Pattern.compile("\\W"); String[] words = pattern.split("one@two#three:four$five"); for (String s : words) { System.out.println("Split using Pattern.split(): " + s); } // using Matcher.replaceFirst() and replaceAll() methods pattern = Pattern.compile("1*2"); matcher = pattern.matcher("11234512678"); System.out.println("Using replaceAll: " + matcher.replaceAll("_")); System.out.println("Using replaceFirst: " + matcher.replaceFirst("_")); } }
上述程序的輸出:
Found the text "AB" starting at 0 index and ending at index 2 Found the text "ab" starting at 3 index and ending at index 5 Found the text "Ab" starting at 6 index and ending at index 8 Split using Pattern.split(): one Split using Pattern.split(): two Split using Pattern.split(): three Split using Pattern.split(): four Split using Pattern.split(): five Using replaceAll: _345_678 Using replaceFirst: _34512678
以上是“Java正則表達(dá)式怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!