命令执行顺序控制与管道

  通常情况下,我们每次只能在终端输入一条命令,按下回车执行,执行完成后,我们再输入第二条命令,然后再按回车执行……,当有时候我们会一次输入多条命令,这个时候的执行过程又是如何的呢?下面我们将学习命令的执行顺序的控制问题。

顺序执行多条命令

我们以往是输入命令回车运行,再输入再运行,
  $ sudo apt-get update
  $ sudo apt-get install some-tool
  $ some-tool
现在我们使用 ;来完成一次输入,然后顺序执行,
  $ sudo apt-get update;sudo apt-get install some-tool;some-tool

有选择的执行命令

which cowsay>/dev/null && cowsay -f head-in ohch~
  上面的&&就是用来实现选择性执行的,它表示如果前面的命令执行结果返回0则执行后面的,否则不执行(返回1),即你如果没有安装cowsay,什么也不执行,如果安装了cowsay,会执行&&后面的语句。你可以从$?环境变量获取上一次命令的返回结果:
在这里插入图片描述

  ||在这里就是与&&相反的控制效果,当上一条命令执行结果为≠0($?≠0)时则执行它后面的命令,这是shell里赋予||&&特别的功能,其另外的功能与C语言一样,是或与并且。
我们还可以结合着&&和||来实现一些操作,比如:
  which cowsay>/dev/null && echo "exist" || echo "not exist"
表示如果前面的命令执行结果返回0则执行&&后面的命令,否则执行||后面的命令。

管道

  管道是一种通信机制,通常用于进程间的通信(也可通过socket进行网络通信),它表现出来的形式就是将前面每一个进程的输出(stdout)直接作为下一个进程的输入(stdin)。
  管道又分为匿名管道和具名管道。我们在使用一些过滤程序时经常会用到的就是匿名管道,在命令行中由|分隔符表示, | 在前面的内容中我们已经多次使用到了。具名管道简单的说就是有名字的管道,通常只会在源程序中用到具名管道。下面我们就将通过一些常用的可以使用管道的"过滤程序"来帮助我们熟练管道的使用。
管道命令入门:
  ls -al /etc
查看/etc目录下有哪些文件和目录,有太多内容,屏幕不能完全显示。
  ls -al /etc | less
  ls -al /etc为前一个命令,|后的less为后一个命令,通过管道将前一个命令(ls)的输出作为下一个命令(less)的输入,然后就可以一行一行地看。

cut命令

  其功能是用于打印每一行的某些字段。如打印/etc/passwd文件中以:为分隔符的第1个字段和第6个字段分别表示用户名和其家目录:
  cut /etc/passwd -d ':' -f 1,6
在这里插入图片描述
打印/etc/passwd文件中每一行的前N个字符:
  $ cut /etc/passwd -c -5 //前五个(包含第五个)
  $ cut /etc/passwd -c 5- //前五个之后的(包含第五个)
  $ cut /etc/passwd -c 5 //第五个
  $ cut /etc/passwd -c 2-5 //2到5之间的(包含第五个)

grep命令

  在文本中或stdin中查找匹配字符串,grep命令是很强大的,它结合正则表达式可以实现很复杂却很高效的匹配和查找。
grep命令的一般形式为:
  grep [命令选项]... 用于匹配的表达式 [文件]...
  先体验一下,我们搜索/home/shiyanlou目录下所有包含"shiyanlou"的文本文件,并显示出现在文本中的行号:
  grep -rnI "shiyanlou" ~
在这里插入图片描述
  -r参数表示递归搜索子目录中的文件,-n表示打印匹配项行号,-I表示忽略二进制文件。这个操作实际没有多大意义,但可以感受到grep命令的强大与实用。
当然也可以在匹配字段中使用正则表达式:
$ export | grep ".*yanlou$" //查看环境变量中以"yanlou"结尾的字符串
在这里插入图片描述
其中$就表示一行的末尾。

wc命令

  简单小巧的计数工具。wc 命令用于统计并输出一个文件中行、单词和字节的数目,比如输出/etc/passwd文件的统计信息(一般数目是递增的):
  wc /etc/passwd
分别只输出行数、单词数、字节数、字符数和输入文本中最长一行的字节数:
  $ wc -l /etc/passwd //行数
  $ wc -w /etc/passwd //单词数
  $ wc -c /etc/passwd //字节数
  $ wc -m /etc/passwd //字符数
  $ wc -L /etc/passwd //最长行字节数
注意:对于西文字符来说,一个字符就是一个字节,但对于中文字符一个汉字是大于2个字节的,具体数目是由字符编码决定的。
再来结合管道来操作一下,下面统计 /etc下面所有目录数(行数):
  ls -dl /etc/*/ | wc -l

sort命令

  功能很简单就是将输入按照一定方式排序,然后再输出,它支持的排序有按字典排序,数字排序,按月份排序,随机排序,反转排序,指定特定字段进行排序等等。
默认为字典排序:
  cat /etc/passwd | sort
反转排序:
  cat /etc/passwd | sort -r
按特定字段排序:
  cat /etc/passwd | sort -t':' -k 3
  上面的-t参数用于指定字段的分隔符,这里是以":"作为分隔符;-k 字段号用于指定对哪一个字段进行排序。这里/etc/passwd文件的第三个字段为数字,默认情况下是以字典序排序的。
如果要按照数字排序就要加上-n参数:
  cat /etc/passwd | sort -t':' -k 3 -n //对第三字段按数字排序
注意观察第二个冒号后的数字:
在这里插入图片描述

uniq去重命令

uniq命令可以用于过滤或者输出重复行。

  1. 过滤重复行
      我们可以使用history命令查看最近执行过的命令(实际为读取${SHELL}_history文件,如我们环境中的~/.zsh_history文件),不过你可能只想查看使用了哪个命令而不需要知道具体干了什么,那么你可能就会要想去掉命令后面的参数然后去掉重复的命令:
      history | cut -c 8- | cut -d ' ' -f 1 | uniq
      仔细看你会发现它确实去重了,只是不那么明显,之所以不明显是因为uniq命令只能去连续重复的行,不是全文去重,所以要达到预期效果,我们先排序:
      $ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq
    或者
      $ history | cut -c 8- | cut -d ' ' -f 1 | sort -u
    Linux大繁至简,一个命令只干一件事却能干到最好。

  2. 输出重复行
    输出重复过的行(重复的只输出一个)及重复次数
      $ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -dc
    输出所有重复的行
      $ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -D

轻松一下

  $ sudo apt update
  $ sudo apt install -y aview imagemagick
  $ wget http://labfile.oss.aliyuncs.com/courses/1/Linus.png
  $ asciiview Linus.png
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值