正则表达式 – 有没有可能的方法来匹配第n个字符?

参见英文答案 > How can I extract the nth occurrence of a match in a Perl regex?                                    7个
我的输入数据如下.我想把这个词分组在 – 的第6和第7位之间.

my $sa = "a1a1a1-b1b1b1-c-ddd-eee-fff-gggggg-hHhH-iiii-j-KKKKK";

为此,实际的正则表达式是

/[^-]+-[^-]+-[^-]+-[^-]+-[^-]+-([^-]+)-/

为了构建正则表达式,我尝试如下,

my $avc = "[^-]+-" x 5 . "([^-]+)-";

my $ar = qr"$avc";

$sa =~m/$ar/g;

print $1;

我怀疑,正则表达式中是否有任何选项可用.不使用x.我怎么能在一个正则表达式中做到这一点?

解决方法

使用 limiting repetition quantifier

/(?:[^-]+-){5}([^-]+)-/

Regex explanation here.

捕获组可以在重复组内,只有最后一个被捕获.

/(?:([^-]+)-){6}/

Regex explanation here.

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...