分组:
定义:
在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
(.):匹配任意一个字符,并将其捕获为第一组(\1就是引用这个被捕获的字符)。
\\1*:表示匹配前面捕获的第一组(即与第一个字符相同的字符)零个或多个。
.+:匹配一个或多个任意字符(除换行符外)。
\\1:再次引用第一组捕获的字符,要求以与开头相同的字符结尾。
捕获分组 练习 2:
任务:把重复的内容 替换为 单个的
String str = "今天有亿亿亿亿亿点点点懒懒懒";
String regex="(.)\\1+";
String s = str.replaceAll(regex, "$1");
System.out.println(s);//今天有亿点懒
(.)表示把重复内容的第一个字符看做一组
\\1+表示第一组字符至少再出现一次
$1 表示把正则表达式中第一组的内容,再拿出来用
非捕获分组:
分组之后不需要再用本组数据,仅仅是把数据括起来。不占组号
如:(在“带条件爬取”中已经见过)文章来源:https://www.toymoban.com/news/detail-813625.html
文章来源地址https://www.toymoban.com/news/detail-813625.html
到了这里,关于正则表达式-分组括号以及捕获分组的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!