我想反转文本文件(或stdin)中的行顺序,保留每行的内容。

因此,从以下内容开始:

foo
bar
baz

我希望最后

baz
bar
foo

是否有用于此的标准UNIX命令行实用程序?


当前回答

对于Emacs用户:C-x h(选择整个文件),然后是M-x反向区域。也适用于仅选择部分或行并恢复这些部分或行。

其他回答

请尝试以下命令:

grep -n "" myfile.txt | sort -r -n | gawk -F : "{ print $2 }"

您可以在命令行上使用Perl:

perl-e'my@b=();而(<>){push(@b,$_);};打印联接(“”,反向(@b));'原始>版本

tac <file_name>

例子:

$ cat file1.txt
1
2
3
4
5

$ tac file1.txt
5
4
3
2
1

如果要就地修改文件,可以运行

sed -i '1!G;h;$!d' filename

这样就不需要创建临时文件,然后删除或重命名原始文件,并具有相同的结果。例如:

$tac file > file2
$sed -i '1!G;h;$!d' file
$diff file file2
$

根据埃菲米恩特的回答,这几乎做到了,但不是完全做到了我想要的。

以下是著名的sed技巧:

# reverse order of lines (emulates "tac")
# bug/feature in HHsed v1.5 causes blank lines to be deleted
sed '1!G;h;$!d'               # method 1
sed -n '1!G;h;$p'             # method 2

(说明:在保留缓冲区、交换缓冲区和保留缓冲区之前准备非初始行,在末尾打印输出行)

或者(以更快的执行速度)从awk一行代码:

awk '{a[i++]=$0} END {for (j=i-1; j>=0;) print a[j--] }' file*

如果你记不住了,

perl -e 'print reverse <>'

在具有GNU实用程序的系统上,其他答案更简单,但并不是所有的世界都是GNU/Linux。。。