正則表達式是一種強大而靈活的文本處理工具。使用它我們能以編程的方式,構造復雜的文本模式,並對輸入的字符串進行搜索。一旦找到了匹配這些模式的部分,你就能夠隨心所欲地對它們進行處理。
關於正則表達式的語法,網上對此有介紹的文章實在是多不勝數,實在找不到,還可以查看Java的API文檔,就不多介紹了。這里主要介紹一個可以測試正則表達式的小工具。直接上代碼:

1 package com.test.stringregex; 2 //{Args: abcabcabcdefabc "abc+" "(abc)+" "(abc){2,}"} 3 import java.util.regex.Matcher; 4 import java.util.regex.Pattern; 5 6 public class TestRegularExpression { 7 public static void main(String[] args) { 8 if(args.length < 2) { 9 System.out.println("Usage:\njava TestRegularExpression " + 10 "characterSequence regularExpression+"); 11 System.exit(0); 12 } 13 System.out.println("Input: \"" + args[0] + "\""); 14 for(String arg : args) { 15 System.out.println("Regular expression: \"" + arg + "\""); 16 Pattern p = Pattern.compile(arg); 17 Matcher m = p.matcher(args[0]); 18 while(m.find()) { 19 System.out.println("Match \"" + m.group() + "\" at positions " + 20 m.start() + "-" + (m.end() - 1)); 21 } 22 } 23 } 24 }
輸入測試的參數為注釋中的{Args: abcabcabcdefabc "abc+" "(abc)+" "(abc){2,}"},結果如下
第一個控制台參數是將要用來搜索匹配的輸入字符串,后面的一個或多個參數都是正則表達式,用""括起來,這里我分別測試了3個正則表達式"abc+" "(abc)+" "(abc){2,}",在實際使用的過程中可以替換成你想要測試的表達式,以驗證它們是不是具備你所需要的匹配功能。
Pattern對象表示編譯后的正則表達式,已編譯的Pattern對象上的matcher()方法,加上一個輸入字符串,共同構造了一個Matcher()對象。通過調用Matcher()對象的find(),group(),start(),end()方法構成了這個工具類直觀的輸出,正則表達式是否匹配,如何匹配目標字符串(即參數args(0))一目了然。