[英]Bash: remove all lines of input except last n lines
我想删除除了最后一行或前n行之外的所有行,并使用短的单行
例如。:
---
aaaa
bbbb
cccc
dddd
cat/echo/find ... | sed < all except last 2 lines >
应该结果
aaaa
bbbb
---
aaaa
bbbb
cccc
dddd
eeee
ffff
cat/echo/find ... | sed < all except last 2 lines >
应该结果
aaaa
bbbb
cccc
dddd
---
我也需要这个非常高的n。 所以可以设置n = 100左右;)
Thanx任何帮助!
要删除最后两行,您可以使用以下内容:
head -n $(($(wc -l < "$filename") - 2)) "$filename"
不是很优雅,但它应该工作。 我使用wc -l来计算行数,然后我使用head来显示第一行数减去2行。
编辑:只保留你可以做的最后N
行
tail -n $N $filename
只保留前N
行,你可以做。
head -n $N $filename
我似乎误解了你的问题,这就是我添加这两个命令的原因。
从头文章页面:
-n, --lines=[-]N
print the first N lines instead of the first 10; with the lead-
ing ‘-’, print all but the last N lines of each file
这意味着... | head -n -2
... | head -n -2
会做你想要的。
作为替代方案,以下内容也可以使用,但我认为它的效率对于大文件来说并不是很好。
tac file | awk 'NR>2' | tac
我想删除除最后一行之外的所有行
最简单的方法是做(让n = 5):
tail -n5 $filename > $filename.tmp && mv $filename.tmp $filename
这将输出最后五行到新文件,然后重命名它。
如果任务相反 - 您需要所有行,但最后5行,您可以这样做:
head -n$((`cat $filename | wc -l` - 5)) $filename > $filename.tmp && mv $filename.tmp $filename
保留文件的最后1000行(例如:alert_PROD.log)
tail -1000 alert_PROD.log > alert_tmp ; cat alert_tmp > alert_PROD.log ; rm alert_tmp
保持前1000行使用head而不是tail命令:
head -1000 alert_PROD.log > alert_tmp ; cat alert_tmp > alert_PROD.log ; rm alert_tmp
要删除inputfile的最后3行:
set 3 inputfile; sed "$(($(sed -n $= $2)-$1+1)),\$d" $2
要打印除文件的前3行以外的所有行,然后除了最后3行之外的所有行:
$ cat -n file
1 a
2 b
3 c
4 d
5 e
6 f
7 g
$ awk -v sz="$(wc -l < file)" 'NR>3' file
d
e
f
g
$ awk -v sz="$(wc -l < file)" 'NR<=(sz-3)' file
a
b
c
d
你可以使用头部和尾部:
要删除除前n行之外的所有行:
head -n filename> new_filename
删除除最后n行之外的所有行:
tail -n filename> new_filename
这是一个例子:
$ cat测试
1
2
3
4
五
6
7
8
$ head -2测试
1
2
你也可以试试
awk -vn=2 -f rem.awk input.txt
rem.awk
在哪里
BEGIN { ("wc -l " ARGV[1]) | getline
a=$1-n+1 }
NR<a { print }
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.