1. 命令执行顺序控制
-
&&
表示如果前面的命令执行结果(不是表示终端输出的内容,而是表示命令执行状态的结果)返回0则执行后面的,否则不执行:
shiyanlou:~/ $ which cowsay>/dev/null && echo "Haha" [12:25:56]
Haha
shiyanlou:~/ $ echo $? [12:26:08]
0
环境变量$?
获取上一次命令的返回结果。cowsay
已安装,返回0
,执行echo "Haha"
。
<p>
-
||
表示如果前面的命令执行结果不为0则执行后面的命令:
shiyanlou:~/ $ which cowsay>/dev/null || echo "hah" [12:26:30]
shiyanlou:~/ $ echo $? [12:33:29]
0
||
前面的返回0
,则不执行后面的命令,不输出结果。
<p>
-
&&
与||
结合使用
shiyanlou:~/ $ which cowsay>/dev/null && echo "exist" || echo "not exist"
exist
shiyanlou:~/ $ which cowsay>/dev/null || echo "not exist" && echo "exist"
exist
由结果可见,&&
和 ||
可以任意顺序,不影响结果。下图是上述第一行代码的流程图:
<p>
<p>
2. 管道
管道表现出来的形式就是将前面每一个进程的输出(stdout)直接作为下一个进程的输入(stdin)。分为具名管道和匿名管道。具名管道简单的说就是有名字的管道,通常只会在源程序中用到具名管道。匿名管道则在命令行中由 |
分隔符表示。
-
|
之前进程的输出是之后进程的输入
$ ls -al /etc | less
通过管道将前一个命令ls
的输出作为下一个命令less
的输入。一行一行地查看ls
命令输出的结果,即/etc
目录下的文件和目录。
<p>
-
cut
打印每一行的某个字段
shiyanlou:~/ $ cat /etc/passwd [12:49:36]
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
# 以上为部分结果
先用cat
查看/etc/passwd
,发现其中每一行记录都是以:
来分隔字段的。所以想查看按:
分割之后的第一个字段和第六个字段,可以如下使用cut
命令:
shiyanlou:~/ $ cut /etc/passwd -d ':' -f 1,6 [12:56:27]
root:/root
daemon:/usr/sbin
bin:/bin
# 以上为部分结果
也可以用-c
参数来打印每一行的第N个字符:
# 前五个(包含第五个)
shiyanlou:~/ $ cut /etc/passwd -c -5 [13:00:55]
root:
daemo
bin:x
# 前五个之后的(包含第五个)
shiyanlou:~/ $ cut /etc/passwd -c 5- [13:03:49]
:x:0:0:root:/root:/bin/bash
on:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
x:2:2:bin:/bin:/usr/sbin/nologin
# 第五个
shiyanlou:~/ $ cut /etc/passwd -c 5 [13:04:49]
:
o
x
# 2到5之间的(包含第5个)
shiyanlou:~/ $ cut /etc/passwd -c 2-5 [13:06:03]
oot:
aemo
in:x
<p>
-
grep
命令,在文本中或stdin
中查找匹配字符串
一般形式:grep [命令选项]... 用于匹配的表达式 [文件]...
如下,搜索/home/shiyanlou
目录下所有包含"shiyanlou"
的所有文本文件,并显示出现在文本中的行号:
shiyanlou:~/ $ grep -rnI "shiyanlou" ~ [13:06:31]
/home/shiyanlou/.zshrc:2: export ZSH=/home/shiyanlou/.oh-my-zsh
/home/shiyanlou/Code/shiyanlou_cs1/README.md:1:shiyanlou_cs1
其中,-r
参数表示递归搜索子目录中的文件,-n
表示打印匹配项行号,-I
表示忽略二进制文件。
<p>
-
wc
命令,简单小巧的计数工具
wc
命令用于统计并输出一个文件中行、单词和字节的数目。应用如下:
# 概览
shiyanlou:~/ $ wc /etc/passwd [13:15:03]
28 35 1370 /etc/passwd
# 行数
shiyanlou:~/ $ wc /etc/passwd -l [13:21:08]
28 /etc/passwd
# 单词数
shiyanlou:~/ $ wc /etc/passwd -w [13:21:26]
35 /etc/passwd
# 字节数
shiyanlou:~/ $ wc /etc/passwd -c [13:21:40]
1370 /etc/passwd
# 字符数
shiyanlou:~/ $ wc /etc/passwd -m [13:21:53]
1370 /etc/passwd
# 最长行字节数
shiyanlou:~/ $ wc /etc/passwd -L [13:22:59]
81 /etc/passwd
** 运用管道和 wc
统计 /etc
下面所有目录数:*
shiyanlou:~/ $ ls -dl /etc/*/ | wc -l [13:27:15]
103
<p>
-
sort
排序命令
通常在查看命令后面结合管道使用,如:
# 默认排序
$ cat /etc/passswd | sort
# 逆序
$ cat /etc/passswd | sort
还可以按照特定字段排序:
$ cat /etc/passwd | sort -t':' -k 3 -n
上面的-t
参数用于指定字段的分隔符,这里是以":"
作为分隔符;-k
字段号
用于指定对哪一个字段进行排序。
<p>
-
uniq
去重命令
需要注意的是,uniq
命令只能去连续重复的行,不是全文去重,所以要达到预期效果,可以在去重之前先排序。
shiyanlou:~/ $ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq
** 其中 history
指之前执行过的语句*