use v6;
=begin pod
perl6 中的替换用S///
S有几个可选参数:
:g —(长形式::global)全局匹配:替换掉所有的出现
:i —不区分大小写的匹配
:ii —(长形式: :samecase) 保留大小写:不管用作替换字母的大小写,使用原来被替换的字母的大小写
:mm —(长形式::samemark) 保留重音符号:在上面的例子中,字母 o 上的分音符号被保留并被应用到替换字母 u 上
:nth(n) —只替换第 n 次出现的
:x(n) —至多替换 n 次(助记符: 'x' 作为及时)
:ss —(长形式:samespace)保留空白类型:空白字符的类型被保留,而不管替换字符串中使用的是什么空白字符。在上面的例子中,我们使用换行作为替换,但是原来的空白被保留了。
eg: $name ~~ S/AB/CD/
当使用S/// 的时候, $name 被起了个叫做 $_ 的别名。
S/// 非破坏性地在 $_ 身上执行了替换并返回那个结果字符串。这是智能匹配将要操作的东西。
智能匹配,按照 Str 与 Str 相匹配的规则,会根据替换是否发生来返回 True 或 False(True 意味着没发生, False表示替换成功)
所以, 这个S///只会返回True或False
~~ 智能操作符把它左边的东西起了个叫做 $_ 的别名,然后 ~~ 计算它右侧的东西,然后在右侧这个东西身上调用 .ACCEPTS($_) 方法。
字符串的ACCEPTS()方法:
$str.ACCEPTS('$name') => 如果$name跟$str相同, 测返回true, 反之返回false
$name ~~ $str => $str.ACCEPTS($name)
eg:
> 'abc' ~~ 'abcd'
False
> 'abcd'.ACCEPTS('abc')
False
> 'abc' ~~ 'abc'
True
> 'abcd'.ACCEPTS('abcd')
True
>
=end pod
#在测试前, 我们先看一个例子
> given 'abc' {say $_;}
abc
> given 'abc' {$_;}
abc
> do given 'abc' {$_;}
abc
>
在given中, given的参数会自动转化为$_
这样, 可们可以用这方法返回S///替换后的字符串
> do given 'abc' {S/a/12345/;}
12345bc
> my $str = do given 'abc' {S/a/12345/;}
12345bc
> $str
12345bc
> my $str = S/a/666/ given '1234567890a'
1234567890666
>
#除了用given也可以用For
> for 'a' {say $_}
a
> my $str = do for 'abc' {S:i/A/6/}
(6bc)
>
#关键是这个given/for 能把参数转化为$_
除了S///替换, 还可以用方法:subst
> 'abca'.subst: /a/, 6;
6bca
> 'abca'.subst: /a/, 6, :g;
6bc6
>
> 'abca'.subst: 'a', 6, :g;
6bc6
> 'abca'.subst: 'a', 6;
6bca
>
#第一个参数为正则或字符串, 第二个为要替换成的字符, 第三个跟S///一样, 可选参数, 如:g全局替换
#捕获分组
#subst的第二个参数可以为一个匿名函数, eg:
> say 'meowmix'.subst: /me(.+)/, -> { "$0" };
owmix
#上面例子, 把第一个正则匹配到的全变成捕获后的东西, 也就是owmix
> say 'abc123'.subst: /abc(d)/, -> { $0 };
123
>
还有一个替换方法为: s
小写的 s 会在原字符串上操作。
大写的 S 一般用作无损替换。
eg: $str ~~ s///; S/// given $str;