perl 统计字符串中特定字符出现的次数

perl 统计字符串中特定字符出现的次数  
 最近写程序遇到如题问题,从网上搜了一些相关技巧,如下:
            (利用数组和哈希的方法就不再列出了)
法一:
    
 #!/usr/bin/perl -w 
use strict;  
my $str = 'abcsfsaf#sdagasdga#sdgaghoiiopjh#dsfjkopahkl;fjh#dsjfklpafj '; 
my $count = $str =~ tr/#/#/; 

 统计了字符串$str 中出现的#的个数,在这里用到了转换操作符tr///,简单快速,当之首选。


附上s/// 和tr/// 的区别:
    s///: 替换运算符。s/searchpattern/repalcement/;默认搜索$ _,找出searchpattern,并且用replacement来替换整个匹配的正则表达式。该运算符返回匹配的数量或进行替换的数量,如果没有进行任何匹配,则返回0。
当然也可以指定某个变量,如$perl=~s/searchpattern/repalcement/; 另外,替换运算符也可以使用非斜杠(/)的界限符,如s###.
    tr/// :转换操作符。tr///的作用与替换运算符有些类似,不过它并不使用正则表达式,而且它的运行方式完全不同。转换操作符的句法如下所示:tr/searchment/repalcement/;是把searchment的第一个字符换成replacement的第一个字符,searchment的第二个字符换成replacement的第二个字符,类推 ~~~~~~~
      即:转换操作符t r / / /用于搜索一个字符串,找出searchlist中的各个元素,并用replacementlist中的对应元素对它们进行替换。如果r e p l a c e m e n t l i s t是空的,或者与s e a r c h l i s t相同,那么t r / / /将计算并返回匹配的字符。目标字符串并不被修改。
 

法二: 

my $var = 'TCTCATGTGAAAAACTATATCAATAATATAAAAACA';
my $count = ($var =~ s/A/A/g);
print $count; 
#计算字符串  $var  中出现的A字符,用到了正则匹配s///g 。
 
法三:

my $str = 'abcsfsaf#sdagasdga#sdgaghoiiopjh#dsfjkopahkl;fjh#dsjfklpafj ' ;
my $cc = 0;
my $tmp = 0;
if( $tmp = () = ($str =~ /#/g ) ) {
 $cc += $tmp;
}
print "$cc\n";
        计算字符串 $str 中出现的 # 个数,利用了正则匹配。
        
         该法也可以如下编写,更简洁。
 
#!/usr/bin/perl
#find.pl
my $s;
$s += ( () =  /A/g ) while <>;
print "A : $s\n";  

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Perl的grep命令可以用于从文件或标准输入过滤出符合条件的行。下面是一些常见的示例: 1. 过滤出包含特定字符串的行 ``` # 从文件过滤出包含"hello"的行 grep 'hello' file.txt # 从标准输入过滤出包含"world"的行 echo "hello world" | grep 'world' ``` 2. 过滤出不包含特定字符串的行 ``` # 从文件过滤出不包含"hello"的行 grep -v 'hello' file.txt # 从标准输入过滤出不包含"world"的行 echo "hello world" | grep -v 'world' ``` 3. 过滤出匹配正则表达式的行 ``` # 从文件过滤出匹配"^[A-Z]"的行(以大写字母开头) grep -E '^[A-Z]' file.txt # 从标准输入过滤出匹配"\d+"的行(包含数字) echo "1a 2b 3c" | grep -E '\d+' ``` 4. 过滤出不匹配正则表达式的行 ``` # 从文件过滤出不匹配"^[A-Z]"的行(不以大写字母开头) grep -Ev '^[A-Z]' file.txt # 从标准输入过滤出不匹配"\d+"的行(不包含数字) echo "1a 2b 3c" | grep -Ev '\d+' ``` 5. 显示匹配行的行号 ``` # 从文件过滤出包含"hello"的行,并显示行号 grep -n 'hello' file.txt # 从标准输入过滤出包含"world"的行,并显示行号 echo "hello world" | grep -n 'world' ``` 6. 显示匹配行之前或之后的多少行 ``` # 从文件过滤出"hello"所在的行及其之前的2行 grep -B 2 'hello' file.txt # 从文件过滤出"hello"所在的行及其之后的3行 grep -A 3 'hello' file.txt ``` 7. 统计匹配行的数量 ``` # 统计文件包含"hello"的行数 grep -c 'hello' file.txt # 统计标准输入包含"world"的行数 echo "hello world" | grep -c 'world' ``` 8. 从多个文件过滤出匹配行 ``` # 从file1.txt和file2.txt过滤出包含"hello"的行 grep 'hello' file1.txt file2.txt # 从当前目录下所有txt文件过滤出包含"world"的行 grep 'world' *.txt ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值