正則表達式的分組功能

正則表達式的分組功能

  • A:正則表達式的分組功能
    • 捕獲組可以通過從左到右計算其開括號來編號。例如,在表達式 ((A)(B©)) 中,存在四個這樣的組:

        1     ((A)(B(C))) 
        2     (A)
        3     (B(C)) 
        4     (C) 
        組零始終代表整個表達式。
      
  • B:案例演示
    • a:切割
      需求:請按照疊詞切割: “sdqqfgkkkhjppppkl”;
    • b:替換
      需求:我我…我…我.要…要要…要學…學學…學.編…編編.編.程.程.程…程
      將字符串還原成:“我要學編程”。
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));
	}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章