練習1:編寫一個方法判斷給定的字串是否為全數字組合
練習2:編寫一個方法判斷給定的字串是否為電話號碼
package day7;import java.util.regex.Matcher;import java.util.regex.Pattern;/** * java.util.regex包 * Pattern類主要是編寫Regex規範; * Matcher類主要是執行規範,驗證字串是否符合其規範; */public class RegexDemo {public static void main(String[] args) {String str = "1234";String str1 = "a234";System.out.println(isDigitCom(str));//trueSystem.out.println(isDigitCom(str1));//falseString str2 = "025-12345678";System.out.println(isPhoneNumCom(str2));//true}/** * 判斷給定的字串是否為全數字組合 * @param str 待判斷的字串 * @return 若為全數字組合返回true,否則返回false */public static Boolean isDigitCom(String str){//1.寫規範String regex = "[0-9]+";//regex = "\\d+";//2.將給定的Regex編譯到模式中Pattern p = Pattern.compile(regex);//3.建立匹配給定輸入與此模式的匹配器Matcher m = p.matcher(str);//4.嘗試將整個地區與模式比對。boolean b = m.matches();return b;}/** * 判斷給定的字串是否為電話號碼:025-12345678、0515-1234567 * @param str * @return */public static Boolean isPhoneNumCom(String str){String regex = "[0]{1}\\d{2}-[1-9]{1}\\d{7}|[0]{1}\\d{3}-[1-9]{1}\\d{6}";Pattern p = Pattern.compile(regex);Matcher m = p.matcher(str);Boolean b = m.matches();return b;}}
String類有三個方法支援Regex:
boolean matches(String regex) 告知此字串是否匹配給定的Regex。
String replaceAll(String regex, String replacement) 使用給定的 replacement 替換此字串所有匹配給定的Regex的子字串
String[] split(String regex) 根據給定Regex的匹配拆分此字串。
這樣可以簡化匹配過程:代碼可變為如下:
public class RegexDemo2 {public static void main(String[] args) {//判斷一個字串是否為全數字組合String regex = "[0-9]+";String str = "12324";String str1 = "a234";System.out.println(str.matches(regex));//trueSystem.out.println(str1.matches(regex));//false//判斷一個字串是否為電話號碼String regex2 = "[0]{1}\\d{2}-[1-9]{1}\\d{7}|[0]{1}\\d{3}-[1-9]{1}\\d{6}";String str2 = "025-12345678";System.out.println(str2.matches(regex2));//true}}
Pattern類定義了Regex的規範:常用的如下
規範1:
[abc] 表示字元a、b或c
[^abc] 表示除了a、b或c之外的任一字元
[0-9] 表示0-9之間的任一數字
[a-zA-Z0-9] 表示字母或數字
\\d 表示任一數字
規範2:(X表示一組規範)
X 必須出現一次
X? 出現0或1次
X* 出現0次或0次以上
X+ 出現1次或1次以上
X{n} 必須出現n次
X{n,} 必須出現n次以上
X{n,m} 出現n到m次
規範3:(X、Y表示一組規範)
XY 表示X規範後跟著Y規範
X|Y 表示X規範或Y規範
(X) 表示作為一個擷取的群組規範