这里我从数组的regex
元素手动创建Regex
。
my Regex @reg =
/ foo /,
/ bar /,
/ baz /,
/ pun /
;
my $r0 = @reg[0];
my $r1 = @reg[1];
my Regex $r = / 0 $r0 | 1 $r1 /;
"0foo_1barz" ~~ m:g/<$r>/;
say $/; # (「0foo」 「1bar」)
如何使用for @reg {...}
进行操作?
答案 0 :(得分:6)
如果变量包含正则表达式,则可以在另一个正则表达式中使用它而不需要进一步使用。
第二个技巧是在正则表达式中使用数组变量,这相当于数组元素的析取:
my @reg =
/foo/,
/bar/,
/baz/,
/pun/
;
my @transformed = @reg.kv.map(-> $i, $rx { rx/ $i $rx /});
my @match = "0foo_1barz" ~~ m:g/ @transformed /;
.say for @match;
答案 1 :(得分:3)
my @reg =
/foo/,
/bar/,
/baz/,
/pun/
;
my $i = 0;
my $reg = @reg
.map({ $_ = .perl; $_.substr(1, $_.chars - 2); })
.map({ "{$i++}{$_}" })
.join('|');
my @match = "foo", "0foo_1barz" ~~ m:g/(<{$reg}>) /;
say @match[1][0].Str;
say @match[1][1].Str;
# 0foo
# 2baz
请参阅the docs
编辑:实际上自己阅读文档。将隐式eval更改为$()构造。
编辑:重写了实际工作的答案
编辑:改变了对可怕,可怕黑客的回答