当前位置: 移动技术网 > 科技>操作系统>Linux > 详解Linux高效命令head、tail和cat

详解Linux高效命令head、tail和cat

2018年10月10日  | 移动技术网科技  | 我要评论

linux中提供了多种命令和程序用于浏览文件。无论对于新手、普通用户、高级用户、开发人员还是管理员来说,与诸多文件打交道都是一项艰巨的任务。而如何做到高效更称得上是一门艺术。

今天就让我们来探讨几个最常使用的命令head、tail和cat,多数人对他们都有所了解,但这其中绝大部分人在真正使用的时候恐怕就不知所措了。

1. head

head命令用于获取一个文件的前10行内容。其基本的语法格式如下:

1
head [options] [file(s)]

如下面的命令会打印出“/etc/passwd”的前10行内容:

1
2
3
4
5
6
7
8
9
10
11
12
# head /etc/passwd
 
root:x:0:0:root:/root:/bin/bash 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
bin:x:2:2:bin:/bin:/bin/sh 
sys:x:3:3:sys:/dev:/bin/sh 
sync:x:4:65534:sync:/bin:/bin/sync 
games:x:5:60:games:/usr/games:/bin/sh 
man:x:6:12:man:/var/cache/man:/bin/sh 
lp:x:7:7:lp:/var/spool/lpd:/bin/sh 
mail:x:8:8:mail:/var/mail:/bin/sh 
news:x:9:9:news:/var/spool/news:/bin/sh

如果一次提供了多个文件,那head命令会分别返回每个文件的前10行内容。如:

1
2
3
4
5
6
7
8
9
10
11
12
13
# head /etc/passwd /etc/shadow
 
==> /etc/passwd <== root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin sync:x:5:0:sync:/sbin:/bin/sync shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown halt:x:7:0:halt:/sbin:/sbin/halt mail:x:8:12:mail:/var/spool/mail:/sbin/nologin uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin ==> /etc/shadow <==
root:$6$85e1:15740:0:99999:7:::
bin:*:15513:0:99999:7:::
daemon:*:15513:0:99999:7:::
adm:*:15513:0:99999:7:::
lp:*:15513:0:99999:7:::
sync:*:15513:0:99999:7:::
shutdown:*:15513:0:99999:7:::
halt:*:15513:0:99999:7:::
mail:*:15513:0:99999:7:::
uucp:*:15513:0:99999:7:::

如果想查看多于10行的内容,利用“-n”选项并跟上一个整数则可指定返回的行数。下面的例子将返回“/var/log/yum.log”的前5行内容:

1
2
3
4
5
6
7
# head -n5 /var/log/yum.log
 
jan 10 00:06:49 updated: openssl-1.0.1e-16.el6_5.4.i686
jan 10 00:06:56 updated: openssl-devel-1.0.1e-16.el6_5.4.i686
jan 10 00:11:42 installed: perl-net-ssleay-1.35-9.el6.i686
jan 13 22:13:31 installed: python-configobj-4.6.0-3.el6.noarch
jan 13 22:13:36 installed: terminator-0.95-3.el6.rf.noarch

实际上,“-n”都是不需要的。只需使用一个连字符外加一个整数即可达到同样的效果,注意他们之间不含空格。

1
2
3
4
5
6
7
# head  -5 /var/log/yum.log
 
jan 10 00:06:49 updated: openssl-1.0.1e-16.el6_5.4.i686
jan 10 00:06:56 updated: openssl-devel-1.0.1e-16.el6_5.4.i686
jan 10 00:11:42 installed: perl-net-ssleay-1.35-9.el6.i686
jan 13 22:13:31 installed: python-configobj-4.6.0-3.el6.noarch
jan 13 22:13:36 installed: terminator-0.95-3.el6.rf.noarch

head命令还支持使用“-c”选项返回指定字节长度的内容。例如,下面的命令将返回指定的文件前45字节内容:

1
2
3
# head -c45 /var/log/yum.log
 
jan 10 00:06:49 updated: openssl-1.0.1e-16.el

2. tail

tail命令用于获取一个文本文件的后10行内容。该命令和head很相似,同样支持传入“n”选项来指定行数。

语法格式:

1
# tail [options] [filenames]

下面的命令将返回“access.log”的后10行内容。

1
2
3
4
5
6
7
8
9
10
11
12
# tail access.log
 
1390288226.042      0 172.16.18.71 tcp_denied/407 1771 get http://download.newnext.me/spark.bin? - none/- text/html
1390288226.198      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html
1390288226.210   1182 172.16.20.44 tcp_miss/200 70872 get http://mahavat.gov.in/mahavat/index.jsp pg direct/61.16.223.197 text/html
1390288226.284     70 172.16.20.44 tcp_miss/304 269 get http://mahavat.gov.in/mahavat/i/i-19.gif pg direct/61.16.223.197 -
1390288226.362    570 172.16.176.139 tcp_miss/200 694 get http://p4-gayr4vyqxh7oa-3ekrqzjikvrczq44-if-v6exp3-v4.metric.gstatic.com/v6exp3/redir.html pg 
1390288226.402      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html
1390288226.437    145 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html
1390288226.445      0 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html
1390288226.605      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html
1390288226.808      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html

如果传入了多个文件,那么tail命令将会分别显示出这些文件的后10行内容。

1
2
3
4
5
6
# tail access.log error.log
 
==> access.log <== 1390288226.042      0 172.16.18.71 tcp_denied/407 1771 get http://download.newnext.me/spark.bin? - none/- text/html 1390288226.198      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html 1390288226.210   1182 172.16.20.44 tcp_miss/200 70872 get http://mahavat.gov.in/mahavat/index.jsp pg direct/61.16.223.197 text/html 1390288226.284     70 172.16.20.44 tcp_miss/304 269 get http://mahavat.gov.in/mahavat/i/i-19.gif pg direct/61.16.223.197 - 1390288226.362    570 172.16.176.139 tcp_miss/200 694 get http://p4-gayr4vyqxh7oa-3ekrqzjikvrczq44-if-v6exp3-v4.metric.gstatic.com/v6exp3/redir.html pg  1390288226.402      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html 1390288226.437    145 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html 1390288226.445      0 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html 1390288226.605      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html 1390288226.808      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html ==> error_log <==
[sun mar 30 03:16:03 2014] [notice] digest: generating secret for digest authentication ...
[sun mar 30 03:16:03 2014] [notice] digest: done
[sun mar 30 03:16:03 2014] [notice] apache/2.2.15 (unix) dav/2 php/5.3.3 mod_ssl/2.2.15 openssl/1.0.0-fips configured -- resuming normal operations

同样,你可以利用“-n”来获取最后n行数的内容。

1
2
3
4
5
6
# tail -5 access.log
1390288226.402      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html
1390288226.437    145 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html
1390288226.445      0 172.16.18.53 tcp_denied/407 1723 options http://172.16.25.252/ - none/- text/html
1390288226.605      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html
1390288226.808      0 172.16.16.55 tcp_denied/407 1753 connect ent-shasta-rrs.symantec.com:443 - none/- text/html

或者利用“-c”来指定返回的字节数。

1
2
3
# tail -c5 access.log
 
ymantec.com:443 - none/- text/html

3. cat

cat是使用最为广泛而通用的工具。它将标准输入拷贝至标准输出。在文本文件超出了屏幕范围时,该命令还支持滚动。

语法格式:

1
# cat [options] [filenames] [-] [filenames]

那最常使用的方法要数读取一个文件的所有内容。你要做的就是输入“cat”外带一个空格并在其后跟上文件名即可。

1
2
3
4
5
6
7
8
9
10
11
# cat /etc/passwd
 
root:x:0:0:root:/root:/bin/bash 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
bin:x:2:2:bin:/bin:/bin/sh 
sys:x:3:3:sys:/dev:/bin/sh 
sync:x:4:65534:sync:/bin:/bin/sync 
games:x:5:60:games:/usr/games:/bin/sh 
man:x:6:12:man:/var/cache/man:/bin/sh 
lp:x:7:7:lp:/var/spool/lpd:/bin/sh 

cat命令还用来串联多个文件:

1
2
3
4
5
6
7
8
9
10
11
12
13
# echo 'hi tecmint-team' > 1 
# echo 'keep connected' > 2 
# echo 'share your thought' > 3 
# echo 'connect us tecmint.com@gmail.com' > 4
 
# cat 1 2 3 4 > 5
 
# cat 5
 
hi tecmint-team 
keep connected 
share your thought 
connect us tecmint.com@gmail.com

也可用于创建新文件。可以在cat命令后外加一个输出重定向操作符和新文件的文件名即可。

1
2
3
# cat > tecmint.txt
 
tecmint is the only website fully dedicated to linux.

我们可以定制cat命令的结束符。默认的行为如下:

1
2
3
4
5
6
# cat > test.txt << end
 
i am avishek 
here i am writing this post 
hope your are enjoying 
end
1
2
3
4
5
# cat test.txt
 
i am avishek 
here i am writing this post 
hope your are enjoying

可别低估cat的力量,他还可以用来复制文件!

1
2
3
# cat avi.txt
 
i am a programmer by birth and admin by profession
1
2
3
4
# cat avi.txt > avi1.txt
# cat avi1.txt
 
i am a programmer by birth and admin by profession

那与cat相对的命令是什么呢?它是tac。tac也是linux中的一个命令。让我们用一个例子来展示tac,我想这比什么都强!

我们首先用cat命令来创建一个month文件并在其中输入各月份的单词,每个单词占一行。

1
2
3
4
5
6
7
8
9
10
11
12
13
# cat month
january
february
march
april
may
june
july
august
september
october
november
december

然后来看看tac的效果如何。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
# tac month
 
december
november
october
september
august
july
june
may
april
march
february
january

是不是很有趣呢。以上就是今天的全部内容。

____________________________

推荐阅读:

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网