我想反转文本文件(或stdin)中的行顺序,保留每行的内容。
因此,从以下内容开始:
foo
bar
baz
我希望最后
baz
bar
foo
是否有用于此的标准UNIX命令行实用程序?
我想反转文本文件(或stdin)中的行顺序,保留每行的内容。
因此,从以下内容开始:
foo
bar
baz
我希望最后
baz
bar
foo
是否有用于此的标准UNIX命令行实用程序?
当前回答
在命令结束时输入:|战术指挥中心
tac完全符合您的要求,它“将每个文件写入标准输出,最后一行首先。”
tac与cat:-相反)。
其他回答
最简单的方法是使用tac命令。tac是猫的逆。例子:
$ cat order.txt
roger shah
armin van buuren
fpga vhdl arduino c++ java gridgain
$ tac order.txt > inverted_file.txt
$ cat inverted_file.txt
fpga vhdl arduino c++ java gridgain
armin van buuren
roger shah
编辑下面生成从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]))")
对于Emacs用户:C-x h(选择整个文件),然后是M-x反向区域。也适用于仅选择部分或行并恢复这些部分或行。
碰巧我想高效地获取一个非常大的文本文件的最后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。
如果要就地修改文件,可以运行
sed -i '1!G;h;$!d' filename
这样就不需要创建临时文件,然后删除或重命名原始文件,并具有相同的结果。例如:
$tac file > file2
$sed -i '1!G;h;$!d' file
$diff file file2
$
根据埃菲米恩特的回答,这几乎做到了,但不是完全做到了我想要的。