基本正則表達(dá)式
例子
String regex = "[1-9]\\d{4,14}";
System.out.println("a".matches(regex));
字符類(lèi)
- [abc] a,b或c
- [^abc] 任何字符,除了a,b,c
- [a-zA-Z] a-z或A-Z灰殴,兩頭的字母包括在內(nèi)(范圍)
- [a-d[m-p]] a到d或m到p就是[a-dm-p]
- [a-z&&[def]] d,e,f
- [a-z&&[^bc]] a-z除了b,c
- [a-z&&[^m-p]] a-z,并且不在m-p范圍
預(yù)定義字符類(lèi)
- \d 數(shù)字
- \D 非數(shù)字
- \s 空白字符
- \S 非空白字符
- \w 單詞字符
- \W 非單詞字符
//判斷是否是數(shù)字
String newRegex = "\\d";
System.out.println("a".matches(newRegex));
Greedy數(shù)量詞
- X? X鸡号,一次或一次也沒(méi)有
- X* X琼牧,零次或多次
- X+ X,一次或多次
- X{n} X蔫仙,恰好 n 次
- X{n,} X料睛,至少 n 次
- X{n,m} X,至少 n 次摇邦,但是不超過(guò) m 次
//可以理解為個(gè)數(shù)恤煞,如以下,元素為施籍,d居扒,c任意一個(gè)長(zhǎng)度為5的字符串
String newRegex = "[abc]{5}";
System.out.println("aaaaa".matches(newRegex));
System.out.println("aaa3a".matches(newRegex));
正則表達(dá)式運(yùn)用
//字符串的切割
String s = "小明.小王.小白";
String[] arr = s.split("\\.");
for(int i = 0;i<arr.length;i++) {
System.out.println(arr[i]);
}
//字符串的替換
String string = "1he12312ll213123o435 7word";
String regex = "\\d";
System.out.println(string.replaceAll(regex, ""));
//快快樂(lè)樂(lè)高高興興
String regex = "(.)\\1(.)\\2(.)\\3"; // \\1代表一組又出現(xiàn)一次,\\2代表第二組又出現(xiàn)一次
System.out.println("高高興興".matches(regex));
System.out.println("高高興興哈哈".matches(regex));
//快樂(lè)快樂(lè)
String regex1 = "(..)\\1(..)\\2";
System.out.println("高高興興".matches(regex1));
System.out.println("高興高興高興高興".matches(regex1));
//我要學(xué)編程練習(xí)
String string = "我我我我...要.....學(xué)....學(xué)學(xué).....編編編......程程";
String string1 = string.replaceAll("\\.", "");
String string2 = string1.replaceAll("(.)\\1+", "$1"); //$為第一組數(shù)據(jù)
System.out.println(string2);
//疊詞切割
String string = "waggggghhffaasaabaadasaffdkjaahka";
//將所有XX數(shù)據(jù)替換
String string1 = string.replaceAll("(.)\\1", "a");
String regex2 = "(.)\\1+"; //出現(xiàn)一次或多次
String []arr = string1.split(regex2);
for(int i=0;i<arr.length;i++) {
System.out.println(arr[i]);
}
找到已匹配的字符串
//獲取手機(jī)號(hào)碼
String string = "我的手機(jī)號(hào)碼是18117824033,曾經(jīng)用過(guò)18117224033,還有18127825333";
String regex = "1[3758]\\d{9}";
Pattern p = Pattern.compile(regex);
Matcher m = p.matcher(string);
while (m.find()) {
System.out.println(m.group());
}