一天一个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是两个非常常用的命令,熟练掌握方便查看文件内容。两个很简单,也很相似,所以放在一起写出来。

(0)

相关推荐

  • 一个简单的linux命令 cp

    cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数.但是如果是在shell脚本中执行cp时,没有-i参数时不会询问是否覆盖.这说明命令行和shell脚本的执行方式有些不同. 命令格式 cp [选项]- [-T] 源 目的 命令参数 -a, –archive 等于-dR –preserve=all –backup[=CONTROL 为每个已存在的目标文件创建备份

  • linux find命令之xargs简单概述

    在使用 find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行.但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现溢出错误.错误信息通常是"参数列太长"或"参数列溢出".这就是xargs命令的用处所在,特别是与find命令一起使用. find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样.这样它可以先处理最先获取的一

  • 一个简单的linux命令 mv

    mv命令是用于移动文件或者将文件改名 一.命令格式: mv [选项] 源文件或目录 目标文件或目录 二.命令参数: -b :若需覆盖文件,则覆盖前先行备份. -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖: -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖! -u :若目标文件已经存在,且 source 比较新,才会更新(update) -t  : --target-directory=DIRECTORY move all SOURCE ar

  • 一个简单的linux命令 touch

    linux的touch命令不常用,一般在使用make的时候可能会用到,用来修改文件时间戳,或者新建一个不存在的文件. 命令格式 touch [选项]- 文件- 命令参数 -a 或–time=atime或–time=access或–time=use 只更改存取时间. -c 或–no-create 不建立任何文档. -d 使用指定的日期时间,而非现在的时间. -f 此参数将忽略不予处理,仅负责解决BSD版本touch指令的兼容性问题. -m 或–time=mtime或–time=modify 只更改

  • 一个简单的linux命令 pwd

    pwd命令主要用于查看当前工作目录的完整路径. 主要用法:pwd [option] 常用范例: 1.查看当前完整路径 命令:pwd 输出: [root@localhost ~]# pwd /root [root@localhost ~]# 2.查看链接路径 命令:pwd -P 输出: [root@localhost soft]# cd /etc/init.d [root@localhost init.d]# pwd /etc/init.d [root@localhost init.d]# pwd

  • 每天一个linux命令 chgrp命令

    在lunix系统里,文件或目录的权限的掌控以拥有者及所诉群组来管理.可以使用chgrp指令取变更文件与目录所属群组,这种方式采用群组名称或群组识别码都可以.Chgrp命令就是change group的缩写!要被改变的组名必须要在/etc/group文件内存在才行. 1.命令格式:chgrp [选项] [组] [文件] 2.命令功能: chgrp命令可采用群组名称或群组识别码的方式改变文件或目录的所属群组.使用权限是超级用户. 3.命令参数: 必要参数: -c 当发生改变时输出调试信息 -f 不显

  • linux命令之find命令简单概述

    Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提供了相当多的查找条件,功能很强大.由于find具有强大的功能,所以它的选项也很多,其中大部分选项都值得我们花时间来了解一下.即使系统中含有网络文件系统( NFS),find命令在该文件系统中同样有效,只你具有相应的权限. 在运行一个非常消耗资源的find命令时,很多人都倾向于把它放在后台执行,因为遍历一个大的文件系统可能会花费很长的时间(这里是指30G字节以上的文件系统). 1.命令格式: find pat

  • linux find命令之exec简单概述

    find是我们很常用的一个Linux命令,但是我们一般查找出来的并不仅仅是看看而已,还会有进一步的操作,这个时候exec的作用就显现出来了. exec解释: -exec 参数后面跟的是command命令,它的终止是以;为结束标志的,所以这句命令后面的分号是不可缺少的,考虑到各个系统中分号会有不同的意义,所以前面加反斜杠. {} 花括号代表前面find查找出来的文件名. 使用find时,只要把想要的操作写在一个文件里,就可以用exec来配合find查找,很方便的.在有些操作系统中只允许-exec选

  • 每天一个linux命令 head命令

    head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾. 1.命令格式: head [参数]... [文件]... 2.命令功能: head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行. 3.命令参数: -q 隐藏文件名 -v 显示文件名 -c<字节> 显示字节数 -n<行数> 显示的行数 4.使用实例: 实例1:显示文件的前n行

  • 一个简单的linux命令 tail

    tail命令从指定点开始将文件写到标准输出.使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容. 命令格式 tail[必要参数][选择参数][文件] 命令参数 -f 循环读取 -q 不显示处理信息 -v 显示详细的处理信息 -c<数目> 显示的字节数 -n<行数> 显示行数 –pid=PID 与-f合用,表示在进程ID,PID死掉之后结束. -q, –qui

随机推荐