Java 正則表達式小例子

xmnx 9年前發布 | 2K 次閱讀 Java

正則表達式概念 

正則表達式使用單個字符串來描述、匹配一系列符合某個句法規則的字符串。正則表達式可以用形式化語言理論的方式來表達,它由常量和算子組成,它們分別指示字符串的集合和在這些集合上的運算。

正則表達式用途

  1. 驗證:字符串是否符合指定特征,比如驗證是否是合法的郵件地址;
  2. 查找:從一個長的文本中查找符合指定特征的字符串,比查找固定字符串更加靈活方便;
  3. 替換:比普通的替換更強大,替換符合指定特征的字符串;

正則表達式引擎 

正則表達式的匹配是通過正則表達式引擎實現的。正則表達式引擎分為兩類:

  1. 基于NFA ( Nondeterministic Finite Automata,非確定型有窮狀態自動機);
  2. 基于DFA ( Deterministic Finite Automaton,確定型有窮狀態自動機);

DFA和NFA的區別在于,DFA對于一個狀態和一個輸入,一定會有一個唯一的后續狀態,而NFA可能有多個狀態,也可能沒有。一般來說,DFA正 則在編譯的時候花的時間會多一點,但是在匹配的時候會更快一點。NFA出現較早,Java、.Net、PHP、Ruby、Perl、Python、GNU Emacs、ed、sec、vi、grep都是使用NFA,而DFA只有egrep awk lex flex這些支持。所以,NFA引擎在生產環境里使用較多。

匹配的規則

  1. 優先選擇最左端的結果;
  2. 對標準匹配量詞'{m,n}'、'+'、'*'、'?'優先使用貪婪模式;

Java正則表達式Demo

自己寫了一個demo,從鍵盤獲取pattern,匹配文件 (默認本工程下tests.txt, 也可以自己輸入文件路徑) 中的字符串,并逐行顯示匹配結果,方便驗證自己寫的正則表達式。

    import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexDemo {  
    private String content;  

    public RegexDemo() {  
        this("test.txt"); // 默認這個文件  
    }  

    public RegexDemo(String fileName) {  
        this.content = (readFileToString(new File(fileName)));  
    }  

    /* 匹配符合模式的字符串并逐個顯示 */  
    public void matchNum(String input) {  
        int sum = 1;  
        Pattern pattern = Pattern.compile(input, Pattern.DOTALL); //"."符號可以匹配行尾  
        Matcher matcher = pattern.matcher(content);  
        while (matcher.find()) {  
            System.out.println("Case" + (sum++) + ": " + matcher.group());  
        }  
    }  

    /* 讀取文件到一個字符串 */  
    private String readFileToString(File file) {  
        StringBuilder stringBuilder = new StringBuilder();  
        try {  
            Scanner scanner = new Scanner(file);  
            while (scanner.hasNextLine()) {  
                stringBuilder.append(scanner.nextLine() + "\n");  
            }  
            scanner.close();  
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
        }  
        return stringBuilder.toString();  
    }  

    public static void main(String[] args) {  
        RegexDemo regexTest = new RegexDemo(); //默認用本工程下的text.txt文件  
        Scanner scanner = new Scanner(System.in);  
        String input = null;  
        while (scanner.hasNextLine()) {  
            input = scanner.nextLine();  
            regexTest.matchNum(input);  
        }  
        scanner.close();  
    }  
}  </pre> 


測試文件tests.txt內容:

demo.anonymous@gmail.com
hello@163.com  192.168.20.2
http://www.jb51.net/tools/regex.htm
<p>第一段</p>
http://www.jb51.net/tools/regex.htm

控制臺運行:

[a-zA-z]+://[^\s]* Case1: http://www.jb51.net/tools/regex.htm
Case2: http://www.jb51.net/tools/regex.htm ((2[0-4]\d|25[0-5]|[01]?\d\d?)\.){3}(2[0-4]\d|25[0-5]|[01]?\d\d?) Case1: 192.168.20.2 \w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* Case1: demo.anonymous@gmail.com
Case2: hello@163.comdemo 

參考

 本文由用戶 xmnx 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!