我有一个很长的文件,我想打印,跳过前1,000,000行,例如。

我查看了猫的手册页,但我没有看到任何选项可以这样做。我正在寻找一个命令来执行此操作或一个简单的Bash程序。


当前回答

使用带范围地址的sed delete命令。例如:

sed 1,100d file.txt # Print file.txt omitting lines 1-100.

或者,如果你只想打印一个已知的范围,使用带-n标志的print命令:

sed -n 201,300p file.txt # Print lines 201-300 from file.txt

这个解决方案应该在所有Unix系统上可靠地工作,而不管是否存在GNU实用程序。

其他回答

cat < File > | awk '{if(NR > 6) print $0}'

我发现删除文件前十行最简单的方法:

$ sed 1,10d file.txt

在一般情况下,X是要删除的初始行数,这归功于评论者和编辑:

$ sed 1,Xd file.txt

Use:

sed -n '1d;p'

该命令将删除第一行并打印其余部分。

使用AWK的一个不那么冗长的版本:

awk 'NR > 1e6' myfile.txt

但我建议使用整数。

只是提出一个sed替代方案。要跳过前一百万行,请尝试|sed '1,1000000d'。

例子:

$ perl -wle 'print for (1..1_000_005)'|sed '1,1000000d'
1000001
1000002
1000003
1000004
1000005