分组:
定义:
在java正则表达式中,( )是分组的意思,每组都有一个组号
如何识别分组?
只看左括号,不看右括号,按照左括号的顺序,从左往右,依次为第一组,第二组,第三组等等,如图:
根据左括号分成了三组
正则表达式中分组有两种:
捕获分组,非捕获分组
捕获分组:
可以获取某一组中的内容反复使用
捕获分组 练习 1
需求1:判断一个字符串的开始字符和结束字符是否一致?只考虑一个字符
String regex1="(.).+\\1";
System.out.println("_123_".matches(regex1));//true
System.out.println("_123_1".matches(regex1));//false
(.)表示第一个分组
需求2:判断一个字符串的开始部分和结束部分是否一致?可以有多个字符
String regex2="(.+).+\\1";
System.out.println("ab_123ab_".matches(regex2));//true
System.out.println("asb_123ab_".matches(regex2));//false
需求3:判断一个字符串的开始部分和结束部分是否一致?开始部分内部每个字符也需要一致
String regex3="(.)\\1*.+\\1";
System.out.println("aaa123aaa".matches(regex3));//true
System.out.println("aaa123aab".matches(regex3));//false
捕获分组 练习 2:
任务:把重复的内容 替换为 单个的
String str = "今天有亿亿亿亿亿点点点懒懒懒";
String regex="(.)\\1+";
String s = str.replaceAll(regex, "$1");
System.out.println(s);//今天有亿点懒
非捕获分组:
分组之后不需要再用本组数据,仅仅是把数据括起来。不占组号
如:(在“带条件爬取”中已经见过)