命令执行顺序控制与管道

1. 命令执行顺序控制

  • && 表示如果前面的命令执行结果(不是表示终端输出的内容,而是表示命令执行状态的结果)返回0则执行后面的,否则不执行:
shiyanlou:~/ $ which cowsay>/dev/null && echo "Haha"                 [12:25:56]
Haha
shiyanlou:~/ $ echo $?                                               [12:26:08]
0

环境变量$?获取上一次命令的返回结果。cowsay已安装,返回0,执行echo "Haha"

  • || 表示如果前面的命令执行结果不为0则执行后面的命令:
shiyanlou:~/ $ which cowsay>/dev/null || echo "hah"                  [12:26:30]
shiyanlou:~/ $ echo $?                                               [12:33:29]
0

||前面的返回0,则不执行后面的命令,不输出结果。

  • &&|| 结合使用
shiyanlou:~/ $ which cowsay>/dev/null && echo "exist" || echo "not exist"
exist
shiyanlou:~/ $ which cowsay>/dev/null || echo "not exist" && echo "exist"
exist

由结果可见,&&|| 可以任意顺序,不影响结果。下图是上述第一行代码的流程图:

命令执行顺序控制与管道_第1张图片


2. 管道

管道表现出来的形式就是将前面每一个进程的输出(stdout)直接作为下一个进程的输入(stdin)。分为具名管道匿名管道。具名管道简单的说就是有名字的管道,通常只会在源程序中用到具名管道。匿名管道则在命令行中由 | 分隔符表示。

  • | 之前进程的输出是之后进程的输入
$ ls -al /etc | less

通过管道将前一个命令ls的输出作为下一个命令less的输入。一行一行地查看ls命令输出的结果,即/etc目录下的文件和目录。

  • 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

  • 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表示忽略二进制文件。

  • 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

  • sort排序命令
    通常在查看命令后面结合管道使用,如:
# 默认排序
$ cat /etc/passswd | sort
# 逆序
$ cat /etc/passswd | sort

还可以按照特定字段排序:

$ cat /etc/passwd | sort -t':' -k 3 -n

上面的-t参数用于指定字段的分隔符,这里是以":"作为分隔符;-k字段号
用于指定对哪一个字段进行排序。

  • uniq 去重命令
    需要注意的是,uniq命令只能去连续重复的行,不是全文去重,所以要达到预期效果,可以在去重之前先排序。
shiyanlou:~/ $ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq 

** 其中 history指之前执行过的语句*

你可能感兴趣的:(命令执行顺序控制与管道)