Regex 如何使用单个正则表达式从字符串中删除具有重复字符的单词?
我需要从Perl中的字符串中删除任何包含重复字符的单词。我可以使用Regex 如何使用单个正则表达式从字符串中删除具有重复字符的单词?,regex,perl,Regex,Perl,我需要从Perl中的字符串中删除任何包含重复字符的单词。我可以使用/e标志: $string =~ s/(\w+)/keys %{{map {$_,1} split '', $1}} == length $1 ? $1 : ""/ge; 是否可以使用单个正则表达式而不使用/e $string =~ s/\b\w*(\w)\w*\1\w*\b//g; 看起来很奇怪,但无论如何都有效。它检测所有的双字母,将它扩展为包含更多的字母,并在结束之前匹配两端的空白。
/e
标志:
$string =~ s/(\w+)/keys %{{map {$_,1} split '', $1}} == length $1 ? $1 : ""/ge;
是否可以使用单个正则表达式而不使用/e
$string =~ s/\b\w*(\w)\w*\1\w*\b//g;
看起来很奇怪,但无论如何都有效。
它检测所有的双字母,将它扩展为包含更多的字母,并在结束之前匹配两端的空白。