甲骨文认证体系
Vmware认证体系
AWS亚马逊
阿里云认证体系
红帽认证体系
ZStack云计算认证体系
思科认证体系
华为认证体系
CDA数据分析师认证
达梦认证体系
麒麟
定制化课程
上海腾科技术分享之linux命令隐藏功能
发布日期:2020-06-24 16:36:11阅读次数:

Linux 提供了许多命令来查看文件的内容,包 括 cat、more、head 和 tail,但这只是一个开始。一方面,即使是很显而易见的命令也有很多许多用户不会去使用的选项。还有一些普普通通的命令提供了一些独特的功能。接下来小编将介绍查看文件内容的命令,以及如何定制这些视图以更好地满足你的需求的选项。

cat

cat 命令将文本文件的全部内容发送到终端窗口以供查看。输入 cat数千行内容的文件名将以极快的速度在你的窗口中滚动,除了最后一屏外的其他文本其他都无法看到。对于 Linux 用户来说 cat 命令很熟悉,但即使是这个基本命令也提供了许多有用的选项,例如对输出中的行进行编号,这是我们许多人可能从未使用过的。更进一步,你不仅可以对行进行编号,还可以选择如何编号。

对每行进行编号就像这样:

1. $ cat -n msg 

2.      1  Hello -- 

3.      2 

4.      3  I hope you are having a wonderful day! 

5.      4 

6.      5 

7.      6  That's it for ...       now 

8.      7 

9.      8  bye! 

10.      9 

11.     10  s. 

你也可以只对有内容的行编号。请注意,对于此命令,仅包含空格的行不被视为“空”,而是会被编号。

1. $ cat -b msg 

2.      1  Hello -- 

3.      2  I hope you are having a wonderful day! 

4.      3  That's it for ...       now 

5.      4  bye! 

6.      5  s. 

cat 命令允许你使用 -s 选项忽略重复的空白行,但是要完全忽略空白行你必须添加另一个命令。

1. $ cat -s msg 

2. Hello -- 

3. I hope you are having a wonderful day! 

4. That's it for ...       now 

5. bye! 

6. s. 

要忽略所有空白行,只需如下将 cat 的输出通过管道传递给 grep 命令。 点(.)匹配包含任意字符的文本,因此它将显示任意非空的行,用于结束一行的回车换行做匹配(LCTT 译注:此处原文有误,径改)。

1. $ cat msg | grep . 

2. Hello -- 

3. I hope you are having a wonderful day! 

4. That's it for ...       now 

5. bye! 

6. s. 

-E 选项通过在每行末尾加 $ 符提供视觉提示,来显示行尾是否还有多余的空格。

1. $ cat -E msg 

2. Hello --$ 

3. $ 

4. I hope you are having a wonderful day!  $ 

5. $ 

6. $ 

7. That's it for ...       now$ 

8. $ 

9. bye!$ 

10. $ 

11. s.$ 

使用 -A 时,既可以在每行的末尾显示 $ 字符,并且制表符会显示为 ^I 而不是空白。

1. $ cat -A msg 

2. Hello --$ 

3. $ 

4. I hope you are having a wonderful day!$ 

5. $ 

6. $ 

7. That’s it for ...^Inow$ 

8. $ 

9. bye!$ 

10. $ 

11. s.$ 

使用 head 和 tail 显示文件部分内容

head 和 tail 显示文件的头部或尾部,默认为十行。 你可以使用 -3(显示 3 行)或 -11(显示 11 行)之类的字符串来指定要查看的其它行数。tail 命令与 head 的工作方式相同,但是显示文件的尾部而不是头部。

1. $ head -3 msg 

2. Hello -- 

3. I hope you are having a wonderful day! 

4. $ tail -3 msg 

5. bye! 

6. s. 

你还可以结合使用 head 和 tail 命令来查看文件中间的文本。你只需要选择起点和想要查看行数即可。在此例中,命令将在文件中显示第二个一百行,并在 cat 的帮助下为这些行编号。

1. $ cat -b mybigfile | head -200 | tail -100 

2.    101  Invoice #2020-06-07a sent to vendor 

3.    ... 

使用 more 或者 less 浏览一屏文本

more 命令是一次浏览一屏内容的自然之选,而 less 通过使用上下键盘箭头增加了在文件中上下移动的能力,这样你就可以遍历内容,然后在文件中回退。

使用 od 查看文本的两种方法

od(八进制转储)命令能够以常规文本和一系列 ASCII 值(即该文本在文件中的实际编码方式)的形式查看文件。在下面的例子中可以看到,带编号的行显示了 ASCII 数字值,而其他行则显示了文本和不可打印的字符。

1. $ od -bc msg 

2. 0000000 110 145 154 154 157 040 055 055 012 012 111 040 150 157 160 145 

3.           H   e   l   l   o       -   -  \n  \n   I       h   o   p   e 

4. 0000020 040 171 157 165 040 141 162 145 040 150 141 166 151 156 147 040 

5.               y   o   u       a   r   e       h   a   v   i   n   g 

6. 0000040 141 040 167 157 156 144 145 162 146 165 154 040 144 141 171 041 

7.           a       w   o   n   d   e   r   f   u   l       d   a   y   ! 

8. 0000060 012 012 012 124 150 141 164 047 163 040 151 164 040 146 157 162 

9.          \n  \n  \n   T   h   a   t   '   s       i   t       f   o   r 

10. 0000100 040 056 056 056 011 156 157 167 012 012 142 171 145 041 012 012 

11.               .   .   .  \t   n   o   w  \n  \n   b   y   e   !  \n  \n 

12. 0000120 163 056 012 

13.           s   .  \n 

请注意,换行符显示为 \n(八进制 012),而制表符显示为 \t(八进制 011)。

od 命令特别有用的用途之一是查看非文本文件以获取可以标识文件类型的信息。在这里,我们看到 JFIF(JPEG 文件交换格式)标签,该标签让 file 之类报告文件类型的命令将它标示为 jpg 文件。这里还有很多其他有用的信息,特别是如果你对这些文件的格式感到好奇的话。

在接下来的命令中,我们查看 jpg 文件的开始部分。

1. $ od -bc arrow.jpg | head -12 

2. 0000000 377 330 377 340 000 020 112 106 111 106 000 001 001 000 000 001 

3.         377 330 377 340  \0 020   J   F   I   F  \0 001 001  \0  \0 001 

4. 0000020 000 001 000 000 377 333 000 103 000 003 002 002 002 002 002 003 

5.          \0 001  \0  \0 377 333  \0   C  \0 003 002 002 002 002 002 003 

6. 0000040 002 002 002 003 003 003 003 004 006 004 004 004 004 004 010 006 

7.         002 002 002 003 003 003 003 004 006 004 004 004 004 004  \b 006 

8. 0000060 006 005 006 011 010 012 012 011 010 011 011 012 014 017 014 012 

9.         006 005 006  \t  \b  \n  \n  \t  \b  \t  \t  \n  \f 017  \f  \n 

10. 0000100 013 016 013 011 011 015 021 015 016 017 020 020 021 020 012 014 

11.          \v 016  \v  \t  \t  \r 021  \r 016 017 020 020 021 020  \n  \f 

12. 0000120 022 023 022 020 023 017 020 020 020 377 333 000 103 001 003 003 

13.         022 023 022 020 023 017 020 020 020 377 333  \0   C 001 003 003 

如果我们要 file 命令提供有关此图像的信息,我们可能会看到类似下面这样的信息。file 命令从文件开头的数据中提取了所有这些描述性信息:

1. $ file arrow.jpg 

2. arrow.png: JPEG image data, JFIF standard 1.01, aspect ratio, density 1x1, segment length 16, baseline, precision 8, 500x375, components 3 

使用 jp2a 将文件视为基于文本的图像

1. 如果你只能在命令行工作,并且想了解特定图像包含的内容,那么可以使用 jp2a(jpeg to ascii)之类的工具提供字符渲染。图像在这种格式下的识别程度取决于文件。

今日的社会,linux背后蕴藏的商机吸引了各个领域的共同关注,因此linux人才的需求空前旺盛,从业者的就业前景极其宽广,在腾科教育学习华为认证推出的VMware虚拟机的课程,就可以学习到全面的虚拟化知识,为成为社会需要的人才做准备。