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

因此,从以下内容开始:

foo
bar
baz

我希望最后

baz
bar
foo

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


当前回答

tac <file_name>

例子:

$ cat file1.txt
1
2
3
4
5

$ tac file1.txt
5
4
3
2
1

其他回答

碰巧我想高效地获取一个非常大的文本文件的最后n行。

我尝试的第一件事是tail-n 10000000 file.txt>ans.txt,但我发现它非常慢,因为tail必须查找到位置,然后返回打印结果。

当我意识到这一点时,我切换到另一个解决方案:tac file.txt | head-n 10000000>ans.txt。这一次,搜索位置只需要从末端移动到所需位置,它节省了50%的时间!

带回家消息:

如果尾部没有-r选项,请使用tac-file.txt | head-n n。

BSD尾部:

tail -r myfile.txt

参考:FreeBSD、NetBSD、OpenBSD和OS X手册页。

我真的很喜欢“尾巴-r”的答案,但我最喜欢的呆呆的答案是。。。。

gawk '{ L[n++] = $0 } 
  END { while(n--) 
        print L[n] }' file

编辑下面生成从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]))")

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

即cat文件|排序-r

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

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

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