regex - 计算正则表达式通配符匹配的字符串中特定字符的匹配次数

标签 regex perl bash sed awk

我可以对正则表达式本身中匹配的每个不同字符进行计数吗?

假设正则表达式看起来像 />(.*)[^a]+/

我可以计算组 (.*) 捕获的字符串中的字母 p 的出现次数吗?

最佳答案

您必须捕获匹配的字符串并单独处理它。

这段代码演示

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;
}

输出

' ' - 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

关于regex - 计算正则表达式通配符匹配的字符串中特定字符的匹配次数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11903693/

相关文章:

c - 为什么正则表达式不是 ISO C99 的一部分

java - 从 perl 调用 java 类

bash - 如何回显到新生成的 xterm

linux - awk匹配前两列的值并在空白字段中打印

regex - Perl 与正则表达式匹配一个数字以及字符串中该数字指定的多个后续字符

php - 设置php文件以允许跨域调用

regex - 如何使用正则表达式查找是否在多个不同位置使用了相同字符?

php - 为什么 PHP 中的字符串连接使用句号 "."而不是加号 "+"?

perl - 如何在 Perl 中获取文件的确切完整路径

linux - 查找最大值和最小值并打印文件中的行