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

因此,从以下内容开始:

foo
bar
baz

我希望最后

baz
bar
foo

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


当前回答

不确定我是否错过了什么。用管子分类怎么样

即cat文件|排序-r

对不起,如果我错过了这个问题的要点。我经常用它来扫描系统日志。

在linux中:观看“tail/var/log/syslog |排序-r”

希望它能帮助某人最美好的祝福

其他回答

编辑下面生成从1到10的随机排序的数字列表:

seq 1 10 | sort -R | tee /tmp/lst |cat <(cat /tmp/lst) <(echo '-------') **...**

其中点被替换为实际命令,该命令反转列表

tac

seq 1 10 | sort -R | tee /tmp/lst |cat <(cat /tmp/lst) <(echo '-------') \
<(tac)

python:在sys.stdin上使用[::-1]

seq 1 10 | sort -R | tee /tmp/lst |cat <(cat /tmp/lst) <(echo '-------') \
<(python -c "import sys; print(''.join(([line for line in sys.stdin])[::-1]))")

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

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

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

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

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

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

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

这将同时适用于BSD和GNU。

awk '{arr[i++]=$0} END {while (i>0) print arr[--i] }' filename

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