站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        Java正則表達(dá)式學(xué)習(xí)教程

        本教程旨在幫助你駕馭Java正則表達(dá)式,同時也幫助我復(fù)習(xí)正則表達(dá)式。

        什么是正則表達(dá)式?

        正則表達(dá)式定義了字符串的模式。正則表達(dá)式可以用來搜索、編輯或處理文本。正則表達(dá)式并不僅限于某一種語言,但是在每種語言中有細(xì)微的差別。Java正則表達(dá)式和Perl的是最為相似的。

        Java正則表達(dá)式的類在 java.util.regex 包中,包括三個類:Pattern,Matcher PatternSyntaxException。

        Pattern對象是正則表達(dá)式的已編譯版本。他沒有任何公共構(gòu)造器,我們通過傳遞一個正則表達(dá)式參數(shù)給公共靜態(tài)方法 compile 來創(chuàng)建一個pattern對象。
        Matcher是用來匹配輸入字符串和創(chuàng)建的 pattern 對象的正則引擎對象。這個類沒有任何公共構(gòu)造器,我們用patten對象的matcher方法,使用輸入字符串作為參數(shù)來獲得一個Matcher對象。然后使用matches方法,通過返回的布爾值判斷輸入字符串是否與正則匹配。
        如果正則表達(dá)式語法不正確將拋出PatternSyntaxException異常。
        讓我們在一個簡單的例子里看看這些類是怎么用的吧

          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對String類進(jìn)行了擴(kuò)展,提供了一個matches方法來匹配pattern。在方法內(nèi)部使用Pattern和Matcher類來處理這些東西,但顯然這樣減少了代碼的行數(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匹配,你可以通過調(diào)用String的matches方法省下時間。只有當(dāng)你需要操作輸入字符串或者重用pattern的時候,你才需要使用Pattern和Matches類。

        注意由正則定義的pattern是從左至右應(yīng)用的,一旦一個原字符在一次匹配中使用過了,將不會再次使用。

        例如,正則“121”只會匹配兩次字符串“31212142121″,就像這樣“_121____121″。
        正則表達(dá)式通用匹配符號

        Java正則表達(dá)式學(xué)習(xí)教程

        Java正則表達(dá)式學(xué)習(xí)教程

        Java正則表達(dá)式元字符

        Java正則表達(dá)式學(xué)習(xí)教程

        有兩種方法可以在正則表達(dá)式中像一般字符一樣使用元字符。

        在元字符前添加反斜杠()
        將元字符置于Q(開始引用)和E(結(jié)束引用)間
        正則表達(dá)式量詞

        量詞指定了字符匹配的發(fā)生次數(shù)。

        Java正則表達(dá)式學(xué)習(xí)教程

        量詞可以和character classes和capturing group一起使用。

        例如,[abc]+表示a,b或c出現(xiàn)一次或者多次。

         (abc)+表示capturing group “abc”出現(xiàn)一次或多次。我們即將討論capturing group。

        正則表達(dá)式capturing group

        Capturing group是用來對付作為一個整體出現(xiàn)的多個字符。你可以通過使用()來建立一個group。輸入字符串中和capturing group相匹配的部分將保存在內(nèi)存里,并且可以通過使用Backreference調(diào)用。

        你可以使用matcher.groupCount方法來獲得一個正則pattern中capturing groups的數(shù)目。例如((a)(bc))包含3個capturing groups; ((a)(bc)), (a) 和 (bc)。

        你可以使用在正則表達(dá)式中使用Backreference,一個反斜杠()接要調(diào)用的group號碼。

        Capturing groups和Backreferences可能很令人困惑,所以我們通過一個例子來理解。

          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  

        在第一個例子里,運(yùn)行的時候第一個capturing group是(wd),在和輸入字符串“a2a2″匹配的時候獲取“a2″并保存到內(nèi)存里。因此1是”a2”的引用,并且返回true。基于相同的原因,第二行代碼打印false。

        試著自己理解第三行和第四行代碼。:)

        現(xiàn)在我們來看看Pattern和Matcher類中一些重要的方法。

        我們可以創(chuàng)建一個帶有標(biāo)志的Pattern對象。例如Pattern.CASE_INSENSITIVE可以進(jìn)行大小寫不敏感的匹配。Pattern類同樣提供了和String類相似的split(String) 方法

        Pattern類toString()方法返回被編譯成這個pattern的正則表達(dá)式字符串。

        Matcher類有start()和end()索引方法,他們可以顯示從輸入字符串中匹配到的準(zhǔn)確位置。

        Matcher類同樣提供了字符串操作方法replaceAll(String replacement)和replaceFirst(String replacement)。

        現(xià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á)式學(xué)習(xí)教程,希望對大家的學(xué)習(xí)有所幫助。

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 日本Aⅴ大伊香蕉精品视频| 亚洲第一极品精品无码久久| 久久精品成人免费国产片小草| 国产精品一久久香蕉国产线看观看| 亚洲国产综合精品中文字幕| 国产精品亚洲αv天堂无码| 欧美精品国产精品| 国产精品看高国产精品不卡| 亚洲AV无码久久精品色欲| 精品国产热久久久福利| 8050免费午夜一级国产精品| 精品国产一区二区三区久久| 2021精品国产综合久久| 精品免费久久久久久久| 亚洲av日韩精品久久久久久a| 无码人妻精品一区二区三区99不卡| 国产精品无码无卡无需播放器 | 国产精品 91 第一页| 国产精品亚洲片夜色在线| 国语自产少妇精品视频蜜桃| 蜜臀久久99精品久久久久久小说| 亚洲AV午夜福利精品一区二区 | 久久精品成人| 免费精品久久久久久中文字幕 | 四虎精品成人免费视频| 久久99亚洲综合精品首页| 国产精品自产拍在线18禁 | 国产精品福利自产拍在线观看 | 国产精品 猎奇 另类视频| 国产国产成人久久精品| 成人免费精品网站在线观看影片| 2022国产精品最新在线| 91精品国产综合久久香蕉| 91亚洲精品麻豆| 国产精品无码久久四虎| 国产一区二区三区欧美精品| 国产午夜精品久久久久九九| 黄床大片免费30分钟国产精品| 久久99精品久久久久久齐齐| 网友偷拍日韩精品| 熟妇人妻VA精品中文字幕|