正則表達式的分組功能
- A:正則表達式的分組功能
-
捕獲組可以通過從左到右計算其開括號來編號。例如,在表達式 ((A)(B©)) 中,存在四個這樣的組:
1 ((A)(B(C))) 2 (A) 3 (B(C)) 4 (C) 組零始終代表整個表達式。
-
- B:案例演示
- a:切割
需求:請按照疊詞切割: “sdqqfgkkkhjppppkl”; - b:替換
需求:我我…我…我.要…要要…要學…學學…學.編…編編.編.程.程.程…程
將字符串還原成:“我要學編程”。
- a:切割
package com.heima.regex;
public class Demo07_Regex {
public static void main(String[] args) {
//Demo01();
//Demo02();
/*
* 需求:我我....我...我.要...要要...要學....學學..學.編..編編.編.程.程.程..程
將字符串還原成:“我要學編程”。
*/
String s1 = "我我....我...我.要...要要...要學....學學..學.編..編編.編.程.程.程..程";
String s2 = s1.replaceAll("\\.+", "");
String s3 = s2.replaceAll("(.)\\1+", "$1"); //$1代表第一組中的內容
System.out.println(s3);
}
private static void Demo02() {
//請按照疊詞切割: "sdqqfgkkkhjppppkl";
String s = "sdqqfgkkkhjppppkl";
String regex = "(.)\\1+"; //+代表第一組出現一次到多次
String[] arr = s.split(regex);
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
private static void Demo01() {
//疊詞 快快樂樂,高高興興
String regex = "(.)\\1(.)\\2"; //\\1代表第一組又出現一次 \\2代表第二組又出現一次
System.out.println("快快樂樂".matches(regex));
System.out.println("快樂樂樂".matches(regex));
System.out.println("高高興興".matches(regex));
System.out.println("死啦死啦".matches(regex));
//疊詞 死啦死啦,高興高興
String regex2 = "(..)\\1";
System.out.println("死啦死啦".matches(regex2));
System.out.println("高興高興".matches(regex2));
System.out.println("快快快快".matches(regex2));
}
}