比如说我有以下数据:
ab
cd
ef
zy
ba
cd
我希望能够以匹配第一个字符的方式匹配它,然后根据第一个字符的捕获组匹配第二个字符。
上面示例中的每一行都应该匹配,而cc
或af
之类的行不应该匹配。
详细说明,我想到的东西看起来像这样:
(基于ruby的正则表达式)
/^(?<first>[a-z])\g<first>$/
然而,这与aa
或ac
匹配,这两者都无效,以及预期的ab
。
有没有办法修改捕获组,或者用类似于我想要的语法包围它?
答案 0 :(得分:5)
正则表达式中没有字符算术。你将不得不走很长的路,并表达你的比赛作为一个长期的交替:
ab|ba|bc|cb|....
您可以轻松优化它:
ab|b[ac]|c[bd]...y[xz]|zy
不要费心编写代码来生成它:编写整个字符串应该需要两分钟。 (当然,除非您是@NeilSlater或@ AmalMurali - 请参阅评论。)
看,我已经在
了ab|b[ac]|c[bd]|d[ce]|e[df]|f[eg]|g[fh]|h[gi]|i[hj]...y[xz]|zy
你完成了。