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

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命令来计算它们?


当前回答

Wc -l不计算行数。

是的,这个答案可能有点晚了,但我还没有发现任何人在答案中记录了更健壮的解决方案。

与流行的观点相反,POSIX根本不要求文件以换行符结束。是的,POSIX 3.206 Line的定义如下:

由零个或多个非换行>字符加上一个终止字符组成的序列。

然而,很多人不知道的是,POSIX还将POSIX 3.195不完全行定义为:

文件末尾的一个或多个非换行>字符序列。

因此,没有末尾LF的文件是完全符合posix的。

如果您选择不支持这两种EOF类型,则您的程序不符合posix。

作为一个例子,让我们看一下下面的文件。

1 This is the first line.
2 This is the second line.

不管EOF是什么,我相信你会同意有两条线。你是通过看有多少行被开始,而不是看有多少行被终止来计算的。换句话说,根据POSIX,这两个文件都有相同的行数:

1 This is the first line.\n
2 This is the second line.\n
1 This is the first line.\n
2 This is the second line.

手册页相对清楚地说明了wc计数换行,换行符只是一个0x0a字符:

NAME
       wc - print newline, word, and byte counts for each file

因此,wc甚至没有试图计算你可能称之为“线”的东西。使用wc来计数行数很可能导致计数错误,这取决于输入文件的EOF。

posix兼容的解决方案

可以像上面的示例一样使用grep来计算行数。这个解决方案更加健壮和精确,它支持文件中一行的所有不同风格:

POSIX 3.75空行 POSIX 3.145空线 POSIX 3.195不完整的行 POSIX 3.206线

$ grep -c ^ FILE

其他回答

使用wc:

wc -l <filename>

这将输出<filename>中的行数:

$ wc -l /dir/file.txt
3272485 /dir/file.txt

或者,从结果中省略<filename>使用wc -l < <filename>:

$ wc -l < /dir/file.txt
3272485

你也可以将数据传输到wc:

$ cat /dir/file.txt | wc -l
3272485
$ curl yahoo.com --silent | wc -l
63
wc -l <file.txt>

Or

command | wc -l

如果你想要的只是行数(而不是行数和返回的愚蠢的文件名):

wc -l < /filepath/filename.ext

正如前面提到的,这些方法也有效(但由于其他原因,效果较差):

awk 'END{print NR}' file       # not on all unixes
sed -n '$=' file               # (GNU sed) also not on all unixes
grep -c ".*" file              # overkill and probably also slower

这个drop-in便携式shell函数[ℹ]工作起来很有魅力。只需将以下代码片段添加到.bashrc文件(或shell环境的等效文件)。

# ---------------------------------------------
#  Count lines in a file
#
#  @1 = path to file
#
#  EXAMPLE USAGE: `count_file_lines $HISTFILE`
# ---------------------------------------------
count_file_lines() {
    local subj=$(wc -l $1)
    subj="${subj//$1/}"
    echo ${subj//[[:space:]]}
}

除了bash和zsh之外,它应该完全兼容所有posix兼容的shell。

只是以防万一。在使用find命令的情况下,可以对许多文件进行此操作。

find . -name '*.java' | xargs wc -l