Linux学习笔记(十)——命令执行顺序控制及管道

命令执行顺序的控制

顺序执行多条命令
简单的顺序执行可以使用;完成

有选择的执行命令
使用which来查找是否安装某个命令,如果找到就执行该命令,否则什么也不做

管道

管道是一种通信机制,通常用于进程间的通信(也可通过 socket 进行网络通信),它表现出来的形式就是将前面每一个进程的输出(stdout)直接作为下一个进程的输入(stdin)。
管道又分为匿名管道和具名管道。我们在使用一些过滤程序时经常会用到的就是匿名管道,在命令行中由|分隔符表示。具名管道简单的说就是有名字的管道,通常只会在源程序中用到具名管道。

查看/etc目录下有哪些文件和目录,使用ls命令来查看:

$ ls -al /etc

有太多内容,屏幕不能完全显示,通过管道将前一个命令(ls)的输出作为下一个命令(less)的输入,然后就可以一行一行地看。

$ ls -al /etc | less

cut命令打印每一行的某一字段

打印/etc/passwd文件中以:为分隔符的第 1 个字段和第 6 个字段分别表示用户名和其家目录:

$ cut /etc/passwd -d ':' -f 1,6

在这里插入图片描述

# 打印 /etc/passwd 文件中每一行的前五个(包含第五个)
$ cut /etc/passwd -c -5
# 前五个之后的(包含第五个)
$ cut /etc/passwd -c 5-
# 第五个
$ cut /etc/passwd -c 5
# 2到5之间的(包含第五个)
$ cut /etc/passwd -c 2-5

grep命令在文本中或 stdin 中查找匹配字符串

grep命令的一般形式为:

grep [命令选项]... 用于匹配的表达式 [文件]...
# 搜索 /home/shiyanlo目录下所有包含"shiyanlou"的文本文件,并显示出现在文本中的行号:
$ grep -rnI "shiyanlou" ~

-r 参数表示递归搜索子目录中的文件,-n表示打印匹配项行号,-I表示忽略二进制文件。

也可以在匹配字段中使用正则表达式:

# 查看环境变量中以"yanlou"结尾的字符串,其中$表示一行的末尾
$ export | grep ".*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

在这里插入图片描述
统计 /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命令用于过滤或者输出重复行。

  • 过滤重复行

可以使用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
  • 输出重复行
# 输出重复过的行(重复的只输出一个)及重复次数
$ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -dc
# 输出所有重复的行
$ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -D

参考:
https://www.shiyanlou.com/courses/1/learning/?id=63

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值