我想反转文本文件(或stdin)中的行顺序,保留每行的内容。
因此,从以下内容开始:
foo
bar
baz
我希望最后
baz
bar
foo
是否有用于此的标准UNIX命令行实用程序?
我想反转文本文件(或stdin)中的行顺序,保留每行的内容。
因此,从以下内容开始:
foo
bar
baz
我希望最后
baz
bar
foo
是否有用于此的标准UNIX命令行实用程序?
当前回答
碰巧我想高效地获取一个非常大的文本文件的最后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手册页。
如果你碰巧在vim使用
:g/^/m0
碰巧我想高效地获取一个非常大的文本文件的最后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。
$ (tac 2> /dev/null || tail -r)
试试tac,它在Linux上运行,如果不起作用,可以使用tail-r,它在BSD和OSX上运行。
我真的很喜欢“尾巴-r”的答案,但我最喜欢的呆呆的答案是。。。。
gawk '{ L[n++] = $0 }
END { while(n--)
print L[n] }' file