微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

正则表达式 – 查找重复字符的单词

想要在字典中搜索在第二个和最后一个位置具有相同字符的每个单词,并在某个中间位置搜索一次.

例子:

statement - has the "t" at the second,fourth and last place
severe = has "e" at 2,4,last
abbxb = "b" at 2,3,last

错误

abab = "b" only 2 times not 3
abxxxbyyybzzzzb - "b" 4 times,not 3

我的grep无法正常工作

my @ok = grep { /^(.)(.)[^\2]+(\2)[^\2]+(\2)$/ } @wordlist;

例如该

perl -nle 'print if /^(.)(.)[^\2]+(\2)[^\2]+(\2)$/' < /usr/share/dict/words

打印例如

zarabanda

怎么了.

什么应该是正确的正则表达式?

编辑:

如何捕捉封闭的群体?例如为了

statement - want cantupre: st(a)t(emen)t - for the later use

my $w1 = $1; my w2 = $2; or something like...
这是应该适合您的正则表达式:
^.(.)(?=(?:.*?\1){2})(?!(?:.*?\1){3}).*?\1$

现场演示:http://www.rubular.com/r/bEMgutE7t5

原文地址:https://www.jb51.cc/regex/357035.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐