文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

linux中head,tail命令有什么用

2023-06-09 17:17

关注

这篇文章主要介绍linux中head,tail命令有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

head命令中文介绍:

用法:head [选项]... [文件]...将每个指定文件的头10 行显示到标准输出。如果指定了多于一个文件,在每一段输出前会给出文件名作为文件头。如果不指定文件,或者文件为"-",则从标准输入读取数据。长选项必须使用的参数对于短选项时也是必需使用的。 -c, --bytes=[-]K显示每个文件的前K 字节内容;如果附加"-"参数,则除了每个文件的最后K字节数据外显示剩余全部内容 -n, --lines=[-]K显示每个文件的前K 行内容;如果附加"-"参数,则除了每个文件的最后K 行外显示剩余全部内容 -q, --quiet, --silent不显示包含给定文件名的文件头 -v, --verbose总是显示包含给定文件名的文件头   --help显示此帮助信息并退出   --version显示版本信息并退出K 后面可以跟乘号:b 512, kB 1000, K 1024, MB 1000*1000, M 1024*1024,GB 1000*1000*1000, G 1024*1024*1024, 对于T, P, E, Z, Y 同样适用。

tail命令详解

用法:tail [选项]... [文件]...显示每个指定文件的最后10 行到标准输出。若指定了多于一个文件,程序会在每段输出的开始添加相应文件名作为头。如果不指定文件或文件为"-" ,则从标准输入读取数据。长选项必须使用的参数对于短选项时也是必需使用的。 -c, --bytes=K输出最后K 字节;另外,使用-c +K 从每个文件的第K 字节输出 -f, --follow[={name|descriptor}]即时输出文件变化后追加的数据。-f, --follow 等于--follow=descriptor  -F即--follow=name --retry -n, --lines=K输出最后K 行,代替最后10 行;使用-n +K 从每个文件的第K 字节输出   --max-unchanged-stats=N使用--follow=name, 重新打开一个在N(默认为5)次迭代后没有改变大小的文件来看它是否被解除连接或重命名(这是循环日志文件的通常情况)。由于有inotify,这个选项很少使用。   --pid=PID同 -f 一起使用,当 PID 所对应的进程死去后终止 -q, --quiet, --silent不输出给出文件名的头   --retry即使目标文件不可访问依然试图打开;在与参数--follow=name 同时使用时常常有用。 -s, --sleep-interval=N  with -f, sleep for approximately N seconds               (default 1.0) between iterations.               With inotify and --pid=P, check process P at               least once every N seconds. -v, --verbose      always output headers giving file names   --help显示此帮助信息并退出   --version显示版本信息并退出如果字节数或行数K 的第一个字符是"+",输出从文件开始第K 个项目,否则输出文件最后K 个项目。K 可以使用一下几种单位之一:b 512,kB 1000,K 1024,MB 1000*1000,M 1024*1024,GB 1000*1000*1000,G 1024*1024*1024,以及T,P,E,Z,Y。如果您希望即时追查一个文件的有效名称而非描述内容(例如循环日志),默认的程序动作并不如您所愿。在这种场合可以使用--follow=name 选项,它会使tail 定期追踪打开给定名称的文件,以确认它是否被删除或被其它某些程序重新创建过。

head:  打印文件的前10行(默认)
tail:     打印文件的后10行(默认)

如果你是个典型的开发或者部署人员,是不是觉得开始亲切起来。我们平时用的最多的命令

$tail -f  catalina.out 

$head

实例:

1. 打印head.txt, tail.txt的前10行

$head head.txt tail.txt

代码如下:

 ==> head.txt <==
head.txt内容

==> tail.txt <==

tail.txt内容

2.  打印 1K的内容

$head –c1K head.txt

3.  打印前5行内容

$head -n5 head.txt

4.  打印出最后5行之外的所有行

$head -n -5 head.txt

这里-5表示负5
解读 --help

代码如下:

用法:head [选项]... [文件]...
将每个指定文件的头10 行显示到标准输出。
 如果指定了多于一个文件,在每一段输出前会给出文件名作为文件头。
 如果不指定文件,或者文件为"-",则从标准输入读取数据。
长选项必须使用的参数对于短选项时也是必需使用的。
-c, --bytes=[-]K         显示每个文件的前K 字节内容;
 如果附加"-"参数,则除了每个文件的最后K字节数据外
 显示剩余全部内容
-n, --lines=[-]K           显示每个文件的前K 行内容;
 如果附加"-"参数,则除了每个文件的最后K 行外显示
 剩余全部内容
-q, --quiet, --silent       不显示包含给定文件名的文件头
-v, --verbose               总是显示包含给定文件名的文件头
--help                          显示此帮助信息并退出
--version                     显示版本信息并退出
K 后面可以跟乘号: 
b 512, kB 1000, K 1024, MB 1000*1000, M 1024*1024,
 GB 1000*1000*1000, G 1024*1024*1024, 对于T, P, E, Z, Y 同样适用。

解读:

这里唯一注意:如果不指定文件,或者文件为"-",则从标准输入读取数据。

$tail

实例:

打印一个文件最后10行

$tail tail.txt

跟踪日志,打印文件最后几行,并且保持读取追加数据

tail -f tail.txt

解读--help

用法:tail [选项]... [文件]... 显示每个指定文件的最后10 行到标准输出。  若指定了多于一个文件,程序会在每段输出的开始添加相应文件名作为头。  如果不指定文件或文件为"-" ,则从标准输入读取数据。 长选项必须使用的参数对于短选项时也是必需使用的。 -c, --bytes=K      输出最后K 字节;另外,使用-c +K 从每个文件的第K 字节输出 -f, --follow[={name|descriptor}]  即时输出文件变化后追加的数据。 -F            即--follow=name --retry -n          --lines=K 输出最后K 行,代替最后10 行;span >-n +K  从每个文件的第K 字节输出--max-unchanged-stats=N     使用--follow=name, 重新打开一个在N(默认为5) 次迭代后没有改变大小的文件来看它是否被解除连 接或重命名(这是循环日志文件的通常情况)。 由于有inotify,这个选项很少使用。 --pid=PID       同 -f 一起使用,当 PID 所对应的进程死去后终止 -q              --quiet, --silent      不输出给出文件名的头 --retry           即使目标文件不可访问依然试图打开;在与参数 --follow=name       同时使用时常常有用。 -s             --sleep-interval=N with -f, sleep for approximately N seconds (default 1.0) between iterations. With inotify and--pid=P, check process P at least once every N seconds. -v          --verbose always output headers giving file names             --help 显示此帮助信息并退出              --version 显示版本信息并退出  如果字节数或行数K 的第一个字符是"+",输出从文件开始第K 个项目,否则输出文件  最后K 个项目。K 可以使用一下几种单位之一: b 512,kB 1000,K 1024,MB 1000*1000,M 1024*1024,  GB 1000*1000*1000,G 1024*1024*1024,以及T,P,E,Z,Y。

解读:

1. 区别-f 和-F

借网上一例子:
窗口1 输入 

$while [ "true" ] ; do date >>test.log; sleep 1 ; done;

#每隔一秒传入一个日期到test.log

窗口2 输入

$tail -f test.log

窗口3 输入

$rm test.log

此时窗口2 则停止打印,而test.log已经重新生成

如果采用-F的形式,也会重新生成一个新的test.log,但会自动重新读取 

以上是“linux中head,tail命令有什么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯