一天一个shell命令 linux文本操作系列-head,tail命令详解

 更新时间:2016年06月05日 16:20:29   投稿:mdxy-dxy  
这篇文章主要介绍了一天一个shell命令 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

实例:

1.打印一个文件最后10行

$tail tail.txt

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

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 style="color: #000000">-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,但会自动重新读取 

收尾

tail和head是两个非常常用的命令,熟练掌握方便查看文件内容。两个很简单,也很相似,所以放在一起写出来。

您可能感兴趣的文章:

相关文章

  • linux批量备份服务器配置文件和目录的脚本

    linux批量备份服务器配置文件和目录的脚本

    这篇文章主要介绍了linux下批量备份服务器配置文件和目录的方法,需要的朋友可以参考下
    2013-08-08
  • vim命令汇总

    vim命令汇总

    本文主要介绍了vim命令汇总,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • Linux 日常常用指令及应用小结

    Linux 日常常用指令及应用小结

    最近在学习一些基本的Linux指令,在这里总结一下,在搭环境中常用的一些指令,熟悉这些指令就基本能够使用CentOS进行日常操作了
    2017-08-08
  • 每天一个linux命令之locate 命令

    每天一个linux命令之locate 命令

    locate命令可以在搜寻数据库时快速找到档案,数据库由updatedb程序来更新,updatedb是由cron daemon周期性建立的,这篇文章主要介绍了每天一个linux命令之locate 命令的相关资料,需要的朋友可以参考下
    2016-11-11
  • linux修改文件名的三种方法

    linux修改文件名的三种方法

    我们在使用linux系统过程中为了便于记忆或整理维护,经常需要对文件名进行修改,下面文章介绍了linux系统的三种修改文件名称的方式,需要的朋友可以参考下
    2023-09-09
  • shell替换文件中的文件路径脚本分享

    shell替换文件中的文件路径脚本分享

    这篇文章主要介绍了shell替换文件中的文件路径脚本,需要的朋友可以参考下
    2014-03-03
  • 获取两个日期间隔时间的shell脚本代码

    获取两个日期间隔时间的shell脚本代码

    获取两个日期间隔时间的shell脚本,对于正在研究shell操作日期的朋友来讲,这个小例子,值得研究
    2013-02-02
  • UNIX sh(Bourne Shell)脚本里面使用数组的两种方法

    UNIX sh(Bourne Shell)脚本里面使用数组的两种方法

    这篇文章主要介绍了UNIX sh(Bourne Shell)脚本里面使用数组的两种方法 ,需要的朋友可以参考下
    2016-12-12
  • Linux链接命令的实例详解

    Linux链接命令的实例详解

    这篇文章主要介绍了Linux链接命令的实例详解的相关资料,希望通过本文大家能掌握Linux链接命令的使用方法,需要的朋友可以参考下
    2017-08-08
  • 如何使用date获取时间戳

    如何使用date获取时间戳

    这篇文章主要介绍了如何使用date获取时间戳,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08

最新评论