我有一个文件,foo.txt,包含以下行:

a
b
c

我想要一个简单的命令,导致foo.txt的内容为:

a
b

当前回答

你也可以试试这个方法:删除最后n行数的例子。

= 0;While [$a -lt 4];do sed -i '$ d' output.txt;A =expr $ A + 1;完成

删除文件(output.txt)的最后4行。

其他回答

下面是一个使用海绵的解决方案(来自moreutils包):

head -n -1 foo.txt | sponge foo.txt

解决方案总结:

如果您想要一个快速的大文件解决方案,请使用有效的tail或dd方法。 如果你想要一些容易扩展/调整和可移植的东西,可以使用重定向和移动方法。 如果您想要一些易于扩展/调整的东西,文件不是太大,可移植性(即依赖于moreutils包)不是问题,并且您喜欢方形裤子,那么可以考虑海绵方法。

与“重定向和移动”方法相比,海绵方法的一个好处是保留了文件权限。

与“重定向和移动”方法相比,Sponge使用了更多的RAM。这可以提高一些速度(只有20%),但如果你对速度感兴趣,“高效尾巴”和dd方法是可行的。

awk 'NR>1{print buf}{buf = $0}'

本质上,这段代码表示:

对于第一行之后的每一行,打印缓冲行

对于每一行,重置缓冲区

缓冲区延迟了一行,因此最终打印的是第1行到第n-1行

echo -e '$d\nw\nq'| ed foo.txt

你也可以试试这个方法:删除最后n行数的例子。

= 0;While [$a -lt 4];do sed -i '$ d' output.txt;A =expr $ A + 1;完成

删除文件(output.txt)的最后4行。

awk "NR != `wc -l < text.file`" text.file &> newtext.file

这段代码可以达到目的。