红联Linux门户
Linux帮助

wc:统计一个文件里出现某个单词出现的次数

发布时间:2016-08-27 10:16:05来源:linux网站作者:Jacketinsysu
今天碰到一道题是问如何统计一个文件里出现某个单词出现的行数,知道是用wc,但是不知道wc的具体用法。
 
搜索了一下,找到了wc –help的中文版本1(我看得懂英文,只是为了方便大家阅读):
1.命令格式:
wc [选项]文件...
2.命令功能:
统计指定文件中的字节数、字数、行数,并将统计结果显示输出。该命令统计指定文件中的字节数、字数、行数。如果没有给出文件名,则从标准输入读取。wc同时也给出所指定文件的总统计数。
3.命令参数:
-c 统计字节数。
-l 统计行数。
-m 统计字符数。这个标志不能与 -c 标志一起使用。
-w 统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串。
-L 打印最长行的长度。
--help 显示帮助信息
--version 显示版本信息
 
值得注意的是,-c,c应该是count的缩写,统计的是文件的字节数,而不是通常我们想要的“字数”,字数的统计应该用-w,所以上面提到那个问题,可以怎么做呢?wc并没有提供给我们统计特定一个单词的选项,只能查找呗~所以结合grep就可以这样简单写:
grep cout hello.cpp | wc -l
上面命令通过管道串联起来,意思是,查找hello.cpp里所有出现过cout的行,统计行数。
 
但是,问题来了,如果不只想统计行数,而是想精确到个数(一行里可能会出现多次),应该怎么办呢?
这就是grep的作用了2,-o选项(only的意思)表示只选中那些匹配的地方,比如a cout yes, and b cout no.,匹配cout,结果是两行,每行一个cout。所以要想统计出现次数的话,简单加一个选项就好了:
grep -o cout hello.cpp | wc -l
 
本文永久更新地址:http://www.linuxdiyf.com/linux/23660.html