我是这样从字符串中捕获数字的:
my $n1;
if $string1 ~~ /(<[0..4]>)$/ {
$n1 = $0;
} else {
put "$string1 failed regex.";
die;
}
这是很多行,但是我可以这样在一行中复制和编辑字符串:
my $string2 = $group2.subst(/<[0..4]>$/, '');
我仍在学习raku / perl6,我浏览了https://docs.perl6.org/type/Str,但看起来Raku不能做到这一点……但我不确定。
有没有一种方法可以像上面的第一个代码示例一样在一行中捕获子字符串?
我在脚本中重复执行此过程,这确实会缩短脚本
答案 0 :(得分:11)
可以使用解构绑定将匹配的一部分提取到变量中。对于给出的示例,我们可以像这样提取匹配的部分:
my ($n) := "abc123" ~~ /(<[1..4]>+)$/;
say $n; # 「123」
这会扩大到提取匹配的多个部分:
my ($s, $n) := "abc123" ~~ /(<[a..z]>+)(<[1..4]>+)$/;
say $s; # 「abc」
say $n; # 「123」
Raku中捕获的东西本身就是Match
对象,但是也可以在解构中使用强制,以便将其变成整数:
my (Int() $n) := "abc123" ~~ /(<[1..4]>+)$/;
say $n; # 123
say $n.WHAT; # (Int)
它甚至可以与已命名的匹配项一起使用(此处有点虚假,但如果要进行子规则调用则很方便):
my (:$s, :$n) := "abc123" ~~ /$<s>=(<[a..z]>+) $<n>=(<[1..4]>+)$/;
say $s; # 「abc」
say $n; # 「123」
一个明显的缺点是,如果匹配失败,则可以获取异常。不过,值得庆幸的是,这可以与if
结合使用:
if "abc123" ~~ /(<[a..z]>+)(<[1..4]>+)$/ -> ($s, $n) {
say $s;
say $n;
}
同样的语法也起作用,因为解构绑定实际上只是签名的应用。
答案 1 :(得分:8)
也许您正在寻找.match。
my $string1='4';
my $n2 = $string1.match(/(<[0..4]>)$/) // die 'error';
say $n2.values;