我有这样的线,我想知道我有多少行。

09:16:39 AM  all    2.00    0.00    4.00    0.00    0.00    0.00    0.00    0.00   94.00
09:16:40 AM  all    5.00    0.00    0.00    4.00    0.00    0.00    0.00    0.00   91.00
09:16:41 AM  all    0.00    0.00    4.00    0.00    0.00    0.00    0.00    0.00   96.00
09:16:42 AM  all    3.00    0.00    1.00    0.00    0.00    0.00    0.00    0.00   96.00
09:16:43 AM  all    0.00    0.00    1.00    0.00    1.00    0.00    0.00    0.00   98.00
09:16:44 AM  all    0.00    0.00    0.00    0.00    0.00    0.00    0.00    0.00  100.00
09:16:45 AM  all    2.00    0.00    6.00    0.00    0.00    0.00    0.00    0.00   92.00

是否有一种方法可以使用linux命令来计算它们?


当前回答

如果你使用的是某种基于bsd的系统,比如macOS,我建议你使用gnu版本的wc。它不会像BSD wc那样在某些二进制文件上出错。至少它仍然是可用的性能。另一方面,BSD的尾巴是缓慢的 ............ zzzzzzzzzz ...........

至于AWK,只有一个小警告——因为它在默认的行假设下运行,也就是\n,如果你的文件恰好没有一个尾随的新行分隔符,AWK会比BSD或GNU wc多计算1。同样,如果你在管道中完全没有新行,比如echo -n,这取决于你是在END{}部分还是FNR==1测量,NR将是不同的。

其他回答

计数所有行使用:

$ wc -l file

使用以下命令过滤和计数带有图案的行:

$ grep -w "pattern" -c file  

或者使用-v来逆匹配:

$ grep -w "pattern" -c -v file 

查看grep手册页,查看-e,-i和-x参数…

cat file.log | wc -l | grep -oE '\d+'

grep -oE '\d+':只返回数字。

如果你使用的是某种基于bsd的系统,比如macOS,我建议你使用gnu版本的wc。它不会像BSD wc那样在某些二进制文件上出错。至少它仍然是可用的性能。另一方面,BSD的尾巴是缓慢的 ............ zzzzzzzzzz ...........

至于AWK,只有一个小警告——因为它在默认的行假设下运行,也就是\n,如果你的文件恰好没有一个尾随的新行分隔符,AWK会比BSD或GNU wc多计算1。同样,如果你在管道中完全没有新行,比如echo -n,这取决于你是在END{}部分还是FNR==1测量,NR将是不同的。

像这样使用nl:

nl filename

来自man nl:

将每个FILE写入标准输出,并添加行号。与 没有FILE,或者当FILE为-时,读取标准输入。

Wc -l <filename>

这将为您提供输出中的行数和文件名。

Eg.

WC -L 24-11-2019-04-33-01-url_creator.log

输出

63 24-11-2019-04-33-01-url_creator.log

Use

Wc -l <filename>|cut -d\ -f

来获取输出中的行数。

Eg.

url_create .log|cut -d\ -f

输出

63