正则表达式 分组 还有\\1 总结。。

本文通过具体的代码示例展示了如何使用正则表达式来匹配重复的字符,并详细解释了预查视(?=...)和回溯引用(1)的概念及其在实际应用中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载来自:http://bbs.itheima.com/thread-7177-1-1.html

"(\w)((?=\1\1\1)(\1))+

1. (\w) -- \w,一个字符,括号表示一个子匹配,第一个括号是"\1",第二个括号是"\2",……。
2. (\w)(\1) -- 一个字符,后面紧跟一个相同的字符。

  1.                 // Pattern pattern = Pattern.compile("(\\w)((?=\\1\\1\\1)(\\1))+");
  2.                 Pattern pattern = Pattern.compile("(\\w)(\\1)");
  3.                 Matcher matcher = pattern.matcher("aaa ffffff 999999999");
  4.                 // Matcher matcher = pattern.matcher("aaa 999999");
  5.                 while (matcher.find()) {
  6.                         System.out.print(matcher.group()+" | ");
  7.                 }

("aaa ffffff 999999999");aa | ff | ff | ff | 99 | 99 | 99 | 99 |

2. (\\w)(?=\\1\\1\\1)
 Pattern.compile("(\\w)(?=\\1\\1\\1)");

运行得:f | f | f | 9 | 9 | 9 | 9 | 9 | 9 | ,

四个字符连续相同才符合条件,且 index只+1(6个 f 所以是3个了)

如无“?=”:(\\w)(\\1\\1\\1),则是从第五个开始 ffffff 输出:f | xxx)

后面继续验证的,看懵了,先码后看。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值