正则表达式 分组 还有\\1 总结。。
2017-04-09 14:07
169 查看
转载来自:http://bbs.itheima.com/thread-7177-1-1.html
"(\w)((?=\1\1\1)(\1))+
1. (\w) -- \w,一个字符,括号表示一个子匹配,第一个括号是"\1",第二个括号是"\2",……。
2. (\w)(\1) -- 一个字符,后面紧跟一个相同的字符。
// Pattern pattern = Pattern.compile("(\\w)((?=\\1\\1\\1)(\\1))+");
Pattern pattern = Pattern.compile("(\\w)(\\1)");
Matcher matcher = pattern.matcher("aaa ffffff 999999999");
// Matcher matcher = pattern.matcher("aaa 999999");
while (matcher.find()) {
System.out.print(matcher.group()+" | ");
}
("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个了)
ffffff 输出:f | xxx)
后面继续验证的,看懵了,先码后看。。。
"(\w)((?=\1\1\1)(\1))+
1. (\w) -- \w,一个字符,括号表示一个子匹配,第一个括号是"\1",第二个括号是"\2",……。
2. (\w)(\1) -- 一个字符,后面紧跟一个相同的字符。
// Pattern pattern = Pattern.compile("(\\w)((?=\\1\\1\\1)(\\1))+");
Pattern pattern = Pattern.compile("(\\w)(\\1)");
Matcher matcher = pattern.matcher("aaa ffffff 999999999");
// Matcher matcher = pattern.matcher("aaa 999999");
while (matcher.find()) {
System.out.print(matcher.group()+" | ");
}
("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个了)
ffffff 输出:f | xxx)
后面继续验证的,看懵了,先码后看。。。
相关文章推荐
- 正则表达式,以前总结的,大不分来择自网上
- [总结]工作中常用的正则表达式,有了它事半功倍!
- 正则表达式总结
- 正则表达式经典学习总结
- 正则表达式中对各字符集编码范围的总结
- 正则表达式总结
- C#中正则表达式的分组构造
- C#与正则表达式(三)--分组
- JavaScript正则表达式总结
- 正则表达式的JS验证总结
- javascript 正则表达式知识点总结:(转并整理)
- VB的正则表达式,不一样的分组捕获
- 几个C#常用正则表达式的总结
- 几个C#常用正则表达式的总结
- 正则表达式 学习总结
- 正则表达式-分组构造
- JavaScript总结(3)-javascript中应用正则表达式
- 自己总结的一些正则表达式(c#版)
- 自己总结的正则表达式的JS验证!
- 几个C#常用正则表达式的总结