在 Bash 中打印文件,跳过前 X 行[重复]

2024-10-18 09:00:00
admin
原创
195
摘要:问题描述:我有一个很长的文件需要打印,例如跳过前 1,000,000 行。我查看了 cat 手册页,但没有看到任何选项可以执行此操作。我正在寻找执行此操作的命令或简单的 Bash 程序。解决方案 1:使用tail。以下是一些示例:$ tail file.log < Last 10 lines o...

问题描述:

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

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


解决方案 1:

使用tail。以下是一些示例:

$ tail file.log
< Last 10 lines of file.log >

跳过前 N 行:

$ tail -n +<N+1> <filename>
< filename, excluding first N lines. >

例如,跳过前 10 行:

$ tail -n +11 file.log
< file.log, starting at line 11, after skipping the first 10 lines. >

要查看最后 N 行,请省略“+”:

$ tail -n <N> <filename>
< last N lines of file. >

解决方案 2:

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

$ sed 1,10d file.txt

在一般情况下,X需要删除的初始行数为,对此,请向评论者和编辑表示感谢:

$ sed 1,Xd file.txt

解决方案 3:

如果您的系统上有 GNU tail,您可以执行以下操作:

tail -n +1000001 huge-file.log

它是+执行您想要的操作的角色。引用手册页中的一段话:

如果 K(字节数或行数)的第一个字符是“+”,则从每个文件开头的第 K 项开始打印。

因此,正如评论中指出的那样,输入 +1000001 将从前 1,000,000 行之后的第一个项目开始打印。

解决方案 4:

如果您想跳过前两行:

tail -n +3 <filename>

如果你想跳过第一行 x:

tail -n +$((x+1)) <filename>

解决方案 5:

使用 AWK 的不太冗长的版本:

awk 'NR > 1e6' myfile.txt

但我建议使用整数。

解决方案 6:

使用带有范围地址的seddelete命令。例如:

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

或者,如果您只想打印已知范围,请使用带有-n标志的打印命令:

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

无论是否存在 GNU 实用程序,此解决方案都应该能够在所有 Unix 系统上可靠地运行。

解决方案 7:

使用:

sed -n '1d;p'

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

解决方案 8:

如果您想查看前 10 行,可以使用 sed,如下所示:

sed -n '1,10 p' myFile.txt

或者如果您想查看第 20 到第 30 行,您可以使用:

sed -n '20,30 p' myFile.txt

解决方案 9:

您可以使用 head 和 tail 命令执行此操作:

head -n <num> | tail -n <lines to print>

其中 num 是 1e6 + 您要打印的行数。

解决方案 10:

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

例子:

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

解决方案 11:

这个 shell 脚本对我来说很好用:

#!/bin/bash
awk -v initial_line=$1 -v end_line=$2 '{
    if (NR >= initial_line && NR <= end_line) 
    print $0
}' $3

与此示例文件(file.txt)一起使用:

one
two
three
four
five
six

命令(它将从文件的第二行到第四行提取):

edu@debian5:~$./script.sh 2 4 file.txt

此命令的输出:

two
three
four

当然,您可以改进它,例如通过测试所有参数值是否符合预期:-)

解决方案 12:

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

解决方案 13:

我需要做同样的事情并找到了这个线程。

我尝试了“tail -n +”,但它只是打印了所有内容。

更多的 +lines 在提示上运行良好,但事实证明,在无头模式(cronjob)下运行时它的行为完全不同。

我最终自己写了这个:

skip=5
FILE="/tmp/filetoprint"
tail -n$((`cat "${FILE}" | wc -l` - skip)) "${FILE}"
相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1120  
  IPD(Integrated Product Development,集成产品开发)流程是一种广泛应用于高科技和制造业的产品开发方法论。它通过跨职能团队的紧密协作,将产品开发周期缩短,同时提高产品质量和市场成功率。在IPD流程中,CDCP(Concept Decision Checkpoint,概念决策检查点)是一个关...
IPD培训课程   75  
  研发IPD(集成产品开发)流程作为一种系统化的产品开发方法,已经在许多行业中得到广泛应用。它不仅能够提升产品开发的效率和质量,还能够通过优化流程和资源分配,显著提高客户满意度。客户满意度是企业长期成功的关键因素之一,而IPD流程通过其独特的结构和机制,能够确保产品从概念到市场交付的每个环节都围绕客户需求展开。本文将深入...
IPD流程   66  
  IPD(Integrated Product Development,集成产品开发)流程是一种以跨职能团队协作为核心的产品开发方法,旨在通过优化资源分配、提高沟通效率以及减少返工,从而缩短项目周期并提升产品质量。随着企业对产品上市速度的要求越来越高,IPD流程的应用价值愈发凸显。通过整合产品开发过程中的各个环节,IPD...
IPD项目管理咨询   76  
  跨部门沟通是企业运营中不可或缺的一环,尤其在复杂的产品开发过程中,不同部门之间的协作效率直接影响项目的成败。集成产品开发(IPD)作为一种系统化的项目管理方法,旨在通过优化流程和增强团队协作来提升产品开发的效率和质量。然而,跨部门沟通的复杂性往往成为IPD实施中的一大挑战。部门之间的目标差异、信息不对称以及沟通渠道不畅...
IPD是什么意思   70  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用