# cat 命令
cat(英文全拼:concatenate)命令用于连接文件并打印到标准输出设备上。
# 使用权限
所有使用者
# 语法格式
cat [-AbeEnstTuv] [--help] [--version] fileName |
# 参数说明:
-n 或 --number:由 1 开始对所有输出的行数编号。
-b 或 --number-nonblank:和 -n 相似,只不过对于空白行不编号。
-s 或 --squeeze-blank:当遇到有连续两行以上的空白行,就代换为一行的空白行。
-v 或 --show-nonprinting:使用 ^ 和 M- 符号,除了 LFD 和 TAB 之外。
-E 或 --show-ends : 在每行结束处显示 $。
-T 或 --show-tabs: 将 TAB 字符显示为 ^I。
-A, --show-all:等价于 -vET。
-e:等价于 "-vE" 选项;
-t:等价于 "-vT" 选项;
# 实例:
把 textfile1 的文档内容加上行号后输入 textfile2 这个文档里:
cat -n textfile1 > textfile2 |
把 textfile1 和 textfile2 的文档内容加上行号(空白行不加)之后将内容附加到 textfile3 文档里:
cat -b textfile1 textfile2 >> textfile3 |
清空 /etc/test.txt 文档内容:
cat /dev/null > /etc/test.txt |
cat 也可以用来制作镜像文件。例如要制作软盘的镜像文件,将软盘放好后输入:
cat /dev/fd0 > OUTFILE |
相反的,如果想把 image file 写到软盘,输入:
cat IMG_FILE > /dev/fd0 |
注:
- OUTFILE 指输出的镜像文件名。
- IMG_FILE 指镜像文件。
- 若从镜像文件写回 device 时,device 容量需与相当。
- 通常用制作开机磁片。
# tac 命令
tac 命令是 cat 反向写的,它们的功能也相反,作用是将文件内容全部显示在屏幕上,但是是从最后一行开始反向显示。
tac 语法:tac filename。
# more 命令
Linux more 命令类似 cat ,不过会以一页一页的形式显示,更方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 b 键就会往回(back)一页显示,而且还有搜寻字串的功能(与 vi 相似),使用中的说明文件,请按 h 。
# 语法
more [-dlfpcsu] [-num] [+/pattern] [+linenum] [fileNames..] |
# 参数:
- -num 一次显示的行数
- -d 提示使用者,在画面下方显示 [Press space to continue, 'q' to quit.] ,如果使用者按错键,则会显示 [Press 'h' for instructions.] 而不是 ' 哔 ' 声
- -l 取消遇见特殊字元 ^L(送纸字元)时会暂停的功能
- -f 计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上)
- -p 不以卷动的方式显示每一页,而是先清除萤幕后再显示内容
- -c 跟 -p 相似,不同的是先显示内容再清除其他旧资料
- -s 当遇到有连续两行以上的空白行,就代换为一行的空白行
- -u 不显示下引号 (根据环境变数 TERM 指定的 terminal 而有所不同)
- +/pattern 在每个文档显示前搜寻该字串(pattern),然后从该字串之后开始显示
- +num 从第 num 行开始显示
- fileNames 欲显示内容的文档,可为复数个数
# 实例
逐页显示 testfile 文档内容,如有连续两行以上空白行则以一行空白行显示。
more -s testfile |
从第 20 行开始显示 testfile 之文档内容。
more +20 testfile |
# 常用操作命令
- Enter 向下 n 行,需要定义。默认为 1 行
- Ctrl+F 向下滚动一屏
- 空格键 向下滚动一屏
- Ctrl+B 返回上一屏
- = 输出当前行的行号
- :f 输出文件名和当前行的行号
- V 调用 vi 编辑器
- ! 命令 调用 Shell,并执行命令
- q 退出 more
# less 命令
less 与 more 类似,less 可以随意浏览文件,支持翻页和搜索,支持向上翻页和向下翻页。
# 语法
less [参数] 文件 |
# 参数说明:
- -b <缓冲区大小> 设置缓冲区的大小
- -e 当文件显示结束后,自动离开
- -f 强迫打开特殊文件,例如外围设备代号、目录和二进制文件
- -g 只标志最后搜索的关键词
- -i 忽略搜索时的大小写
- -m 显示类似 more 命令的百分比
- -N 显示每行的行号
- -o <文件名> 将 less 输出的内容在指定文件中保存起来
- -Q 不使用警告音
- -s 显示连续空行为一行
- -S 行过长时间将超出部分舍弃
- -x <数字> 将 "tab" 键显示为规定的数字空格
- / 字符串:向下搜索 "字符串" 的功能
- ? 字符串:向上搜索 "字符串" 的功能
- n:重复前一个搜索(与 / 或?有关)
- N:反向重复前一个搜索(与 / 或?有关)
- b 向上翻一页
- d 向后翻半页
- h 显示帮助界面
- Q 退出 less 命令
- u 向前滚动半页
- y 向前滚动一行
- 空格键 滚动一页
- 回车键 滚动一行
- [pagedown]: 向下翻动一页
- [pageup]: 向上翻动一页
# 实例
1、查看文件
less log2013.log |
2、ps 查看进程信息并通过 less 分页显示
ps -ef |less |
3、查看命令历史使用记录并通过 less 分页显示
[root@localhost test]# history | less | |
22 scp -r tomcat6.0.32 root@192.168.120.203:/opt/soft | |
23 cd .. | |
24 scp -r web root@192.168.120.203:/opt/ | |
25 cd soft | |
26 ls | |
……省略…… |
4、浏览多个文件
less log2013.log log2014.log |
说明:
输入 :n 后,切换到 log2014.log
输入 :p 后,切换到 log2013.log
# 附加备注
1. 全屏导航
- ctrl + F - 向前移动一屏
- ctrl + B - 向后移动一屏
- ctrl + D - 向前移动半屏
- ctrl + U - 向后移动半屏
2. 单行导航
- j - 下一行
- k - 上一行
3. 其它导航
- G - 移动到最后一行
- g - 移动到第一行
- q / ZZ - 退出 less 命令
4. 其它有用的命令
- v - 使用配置的编辑器编辑当前文件
- h - 显示 less 的帮助文档
- &pattern - 仅显示匹配模式的行,而不是整个文件
5. 标记导航
当使用 less 查看大文件时,可以在任何一个位置作标记,可以通过命令导航到标有特定标记的文本位置:
- ma - 使用 a 标记文本的当前位置
- 'a - 导航到标记 a 处
# head 命令
head 命令可用于查看文件的开头部分的内容,有一个常用的参数 -n 用于显示行数,默认为 10,即显示 10 行的内容。
# 命令格式:
head [参数] [文件] |
# 参数:
- -q 隐藏文件名
- -v 显示文件名
- -c <数目> 显示的字节数。
- -n <行数> 显示的行数。
# 实例
要显示 runoob_notes.log 文件的开头 10 行,请输入以下命令 (默认带参赛 -n 10):
head runoob_notes.log |
以上命令等价于:
head -n 10 runoon_notes.log |
显示 notes.log 文件的开头 5 行,请输入以下命令:
head -n 5 runoob_notes.log |
显示文件前 20 个字节:
head -c 20 runoob_notes.log |
# tail 命令
tail 命令可用于查看文件的内容,有一个常用的参数 -f 常用于查阅正在改变的日志文件。
tail -f filename 会把 filename 文件里的最尾部的内容显示在屏幕上,并且不断刷新,只要 filename 更新就可以看到最新的文件内容。
# 命令格式:
tail [参数] [文件]
# 参数:
- -f 循环读取
- -q 不显示处理信息
- -v 显示详细的处理信息
- -c <数目> 显示的字节数
- -n <行数> 显示文件的尾部 n 行内容
- --pid=PID 与 - f 合用,表示在进程 ID,PID 死掉之后结束
- -q, --quiet, --silent 从不输出给出文件名的首部
- -s, --sleep-interval=S 与 - f 合用,表示在每次反复的间隔休眠 S 秒
实例
要显示 notes.log 文件的最后 10 行,请输入以下命令:
tail notes.log # 默认显示最后 10 行 |
要跟踪名为 notes.log 的文件的增长情况,请输入以下命令:
tail -f notes.log |
此命令显示 notes.log 文件的最后 10 行。当将某些行添加至 notes.log 文件时,tail 命令会继续显示这些行。 显示一直继续,直到您按下(Ctrl-C)组合键停止显示。
显示文件 notes.log 的内容,从第 20 行至文件末尾:
tail -n +20 notes.log |
显示文件 notes.log 的最后 10 个字符:
tail -c 10 notes.log
# nl 命令
nl 命令的作用和 cat -n 类似,是将文件内容全部显示在屏幕上,并且是从第一行开始显示,同时会自动打印出行号。
# 命令格式:
nl [-bnw] 文件名
# 参数:
-b: 指定行号列出的方式,主要有两种:
-b a: 表示会列出空白行的行号(类似与 cat -n)
-b t: 表示不列出空白行的行号(这个是 nl 命令的默认选项,类似于 cat -b)
-n: 指定行号表示的方法,主要有三种:
-n ln: 行号在自己字段的最左方(也是屏幕的最左方)显示
-n rn: 行号在自己字段的最右方显示,且前面不加 0(默认选项)
-n rz: 行号在自己字段的最右方显示,但前面加 0
-w <数字>: 指定行号字段的占用位数
# sort 命令
Linux sort 命令用于将文本文件内容加以排序。
sort 可针对文本文件的内容,以行为单位来排序。
# 语法
sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符>][+<起始栏位>-<结束栏位>][--help][--verison][文件][-k field1[,field2]] |
# 参数说明:
- -b 忽略每行前面开始出的空格字符。
- -c 检查文件是否已经按照顺序排序。
- -d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
- -f 排序时,将小写字母视为大写字母。
- -i 排序时,除了 040 至 176 之间的 ASCII 字符外,忽略其他的字符。
- -m 将几个排序好的文件进行合并。
- -M 将前面 3 个字母依照月份的缩写进行排序。
- -n 依照数值的大小排序。
- -u 意味着是唯一的 (unique),输出的结果是去完重了的。
- -o <输出文件> 将排序后的结果存入指定的文件。
- -r 以相反的顺序来排序。
- -t <分隔字符> 指定排序时所用的栏位分隔字符。
- +<起始栏位>-< 结束栏位 > 以指定的栏位来排序,范围由起始栏位到结束栏位的前一栏位。
- --help 显示帮助。
- --version 显示版本信息。
- [-k field1 [,field2]] 按指定的列进行排序。
# 实例
在使用 sort 命令以默认的式对文件的行进行排序,使用的命令如下:
sort testfile
sort 命令将以默认的方式将文本文件的第一列以 ASCII 码的次序排列,并将结果输出到标准输出。
使用 cat 命令显示 testfile 文件可知其原有的排序如下:
$ cat testfile # testfile 文件原有排序 | |
test 30 | |
Hello 95 | |
Linux 85 |
使用 sort 命令重排后的结果如下:
$ sort testfile # 重排结果 | |
Hello 95 | |
Linux 85 | |
test 30 |
使用 -k 参数设置对第二列的值进行重排,结果如下:
$ sort testfile -k 2 | |
test 30 | |
Linux 85 | |
Hello 95 |
# uniq 命令
Linux uniq 命令用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。
uniq 可检查文本文件中重复出现的行列。
# 语法
uniq [-cdu][-f<栏位>][-s<字符位置>][-w<字符位置>][--help][--version][输入文件][输出文件] |
# 参数:
- -c 或 --count 在每列旁边显示该行重复出现的次数。
- -d 或 --repeated 仅显示重复出现的行列。
- -f <栏位> 或 --skip-fields=< 栏位 > 忽略比较指定的栏位。
- -s <字符位置> 或 --skip-chars=< 字符位置 > 忽略比较指定的字符。
- -u 或 --unique 仅显示出一次的行列。
- -w <字符位置> 或 --check-chars=< 字符位置 > 指定要比较的字符。
- --help 显示帮助。
- --version 显示版本信息。
- [输入文件] 指定已排序好的文本文件。如果不指定此项,则从标准读取数据;
- [输出文件] 指定输出的文件。如果不指定此选项,则将内容显示到标准输出设备(显示终端)。
# 实例
文件 testfile 中第 2、3、5、6、7、9 行为相同的行,使用 uniq 命令删除重复的行,可使用以下命令:
uniq testfile |
testfile 中的原有内容为:
$ cat testfile #原有内容 | |
test 30 | |
test 30 | |
test 30 | |
Hello 95 | |
Hello 95 | |
Hello 95 | |
Hello 95 | |
Linux 85 | |
Linux 85 |
使用 uniq 命令删除重复的行后,有如下输出结果:
$ uniq testfile #删除重复行后的内容 | |
test 30 | |
Hello 95 | |
Linux 85 |
检查文件并删除文件中重复出现的行,并在行首显示该行重复出现的次数。使用如下命令:
uniq -c testfile |
结果输出如下:
$ uniq -c testfile #删除重复行后的内容 | |
3 test 30 #前面的数字的意义为该行共出现了 3 次 | |
4 Hello 95 #前面的数字的意义为该行共出现了 4 次 | |
2 Linux 85 #前面的数字的意义为该行共出现了 2 次 |
当重复的行并不相邻时,uniq 命令是不起作用的,即若文件内容为以下时,uniq 命令不起作用:
$ cat testfile1 # 原有内容 | |
test 30 | |
Hello 95 | |
Linux 85 | |
test 30 | |
Hello 95 | |
Linux 85 | |
test 30 | |
Hello 95 | |
Linux 85 |
这时我们就可以使用 sort:
$ sort testfile1 | uniq | |
Hello 95 | |
Linux 85 | |
test 30 |
统计各行在文件中出现的次数:
$ sort testfile1 | uniq -c | |
3 Hello 95 | |
3 Linux 85 | |
3 test 30 |
在文件中找出重复的行:
$ sort testfile1 | uniq -d | |
Hello 95 | |
Linux 85 | |
test 30 |