这篇文章给大家分享的是有关Linux如何统计一个文件中特定字符个数的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
统计一个文件中某个字符串的个数,其实就是在在一块沙地里面找石头,有的人看到石头以后,在上面做个标记(grep),然后记住自己做了多少个标记,有的人看到石头以后,把它挖了(tr),最后统计自己挖了多少石头;有的人看到石头以后,把它跳过去(awk),然后统计自己跳了多少次。
<强>这是我用的的文件强>
[root@bzhou 测试]#,cat 文件 hafsdha hahafsdfsdhaha 哈哈以前>我想匹配的是“哈哈# 39;这个字符串
<强> 1。grep的o选项强>
[root@bzhou 测试]#,grep -c & # 39;哈哈# 39;文件 2最开始的时候是用c这个选项,不过- c只能统计一行的,如果一行里面有多个匹配的字符串,那- c就无能为力了。
<强>这个是正确的强>
[root@bzhou 测试]#,grep -o & # 39;哈哈# 39;,file | wc - l 3<强> 2。awk 强>
这个东西要感谢铜上的blackold。
[root@bzhou 测试]#,awk -v RS=& # 39;哈哈# 39;,& # 39;最终获得{print - NR} & # 39;,文件- v去设定一个变量的值,RS是记录的分隔符,默认的是新行(\ n),就是说awk按照一行一行读数据,但是现在RS为& # 39;哈哈# 39;后,就按& # 39;哈哈# 39;读数据了,NR为已读的记录数,n个记录是被n - 1个分隔符分开的,所以就是,NR了。
<强> 3. tr 强>
严格意义上说,tr匹配不了字符串,只能去匹配单个字符。这里就匹配这个文件中“h # 39;的个数。
[root@bzhou 测试]#,tr -cd & # 39; h # 39;, & lt; file |, wc - c 8 [root@bzhou 测试]#,grep -o & # 39; h # 39;, file | wc - l 8- d可以删除某个字符,如果只有- d就会输出删除特定字符后的字符串,但是- c可以反显,这就是显示了被删除的字符。然后可以用wc - c去统计下字符的个数。
感谢各位的阅读!关于“Linux如何统计一个文件中特定字符个数”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
Linux如何统计一个文件中特定字符个数