我正在努力将每个单词中的所有元音加倍。例如:
$string="if it rains, cover with umbrella";
这是我写的代码,但我没有得到正确的输出。
$string=~s/a|e|i|o|u/aa|ee|ii|oo|uu/gi; print $string;
预期输出:iif iit raaiins cooveer wiith uumbreelaa
有人可以帮助我吗?
答案 0 :(得分:8)
替换中的正则表达式应该可以正常工作,但正如您将看到的,替换字符串是一个与匹配无关的简单字符串,除非您捕获正则表达式中的子字符串并在替换字符串中使用它们。
使用字符类匹配一组字符中的任何一个,例如[aeiuo]
。
使用括号“捕获”匹配的一部分,以便您可以在替换字符串中使用它。
my $string = "if it rains, cover with umbrella";
$string =~ s/([aeiuo])/$1$1/g;
print $string;
<强>输出强>
iif iit raaiins, cooveer wiith uumbreellaa
答案 1 :(得分:3)
所有匹配都是在变量$ 1,...,$ 9中捕获的,所以如果你用$ 1替换$ 1,它将重复匹配的任何内容,在这种情况下它将使元音加倍
$string=~ s/(a|e|i|o|u)/\1\1/gi;
print $string;
答案 2 :(得分:1)
如前所述,以下情况可以解决这个问题:
s/([aeiuo])/$1$1/ig; # A => AA
或许你想要
s/([aeiuo])/\L$1$1/ig; # A => aa
以下是适用于任意翻译地图的替代解决方案:
my %map = (
'a' => 'aa',
'e' => 'ee',
'i' => 'ii',
'o' => 'uu',
'u' => 'oo',
);
my $pat =
join '|',
map quotemeta,
sort { length($b) <=> length($a) }
keys(%map);
s/($pat)/$map{$1}/g;
如果你有
,上述工作即使有效( 'foo' => 'bar',
'bar' => 'foo' )
如果您没有类似
的内容,则可以省略sort
行
( 'foo' => 'bar',
'food' => 'baz' )
答案 3 :(得分:0)
您没有打印出错误输出的内容,但您可以简单地用双倍替换每个元音。例如:
$string =~ s/a/aa/g;
$string =~ s/e/ee/g;
$string =~ s/i/ii/g;
$string =~ s/o/oo/g;
$string =~ s/u/uu/g;