您必须捕获匹配的字符串并单独处理它.
此代码演示
use strict;
use warnings;
my $str = '> plantagenetgoosewagonattributes';
if ($str =~ />(.*)[^a]+/) {
my $substr = $1;
my %counts;
$counts{$_}++ for $substr =~ /./g;
print "'$_' - $counts{$_}\n" for sort keys %counts;
}
Run Code Online (Sandbox Code Playgroud)
产量
' ' - 1
'a' - 4
'b' - 1
'e' - 4
'g' - 3
'i' - 1
'l' - 1
'n' - 3
'o' - 3
'p' - 1
'r' - 1
's' - 1
't' - 5
'u' - 1
'w' - 1
Run Code Online (Sandbox Code Playgroud)
在正则表达式之外:
my $p_count = map /p/g, />(.*)[^a]/;
Run Code Online (Sandbox Code Playgroud)
自包含:
local our $p_count;
/
(?{ 0 })
>
(?: p (?{ $^R + 1 })
| [^p]
)*
[^a]
(?{ $p_count = $^R; })
/x;
Run Code Online (Sandbox Code Playgroud)
在这两种情况下,您都可以轻松扩展它以计算所有字母.例如,
my %counts;
if (my ($seq = />(.*)[^a]/) {
++$counts{$_} for split //, $seq;
}
my $p_count = $counts{'p'};
Run Code Online (Sandbox Code Playgroud)