【Linux】学习笔记(十二) Linux 管道

2020-07-02 15:59:54 浏览数 (1)

Linux 管道

管道的体验

$ ls -al /etc | less 体验管道 的使用

通过管道将前一个命令(ls)的输出作为下一个命令(less)的输入,然后就可以一行一行地看。

1. cut 命令 显示信息

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

打印/etc/passwd文件中每一行的前 N 个字符

代码语言:javascript复制
# 前五个(包含第五个)
$ cut /etc/passwd -c -5
# 前五个之后的(包含第五个)
$ cut /etc/passwd -c 5-
# 第五个
$ cut /etc/passwd -c 5
# 2到5之间的(包含第五个)
$ cut /etc/passwd -c 2-5

2. grep 命令 匹配查找

结合正则表达式可以实现很复杂却很高效的匹配和查找

grep命令的一般形式为:

grep [命令选项]... 用于匹配的表达式 [文件]...

搜索/home/shiyanlou(当前目录)目录下所有包含"shiyanlou"的文本文件,并显示出现在文本中的行号: $ grep -rnI "shiyanlou" ~

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

引入正则表达式 查看环境变量中以"yanlou"结尾的字符串 $ export | grep ".*yanlou$"

  • $就表示一行的末尾

3. wc 命令计数

分别只输出行数、单词数、字节数、字符数和输入文本中最长一行的字节数:

代码语言:javascript复制
$ 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

4. 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

5. uniq 去重命令

代码语言:javascript复制
$ history | cut -c 8- | cut -d ' ' -f 1 | uniq

uniq命令只能去连续重复的行,不是全文去重,所以要达到预期效果,我们先排序:

代码语言:javascript复制
$ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq
# 或者$ history | cut -c 8- | cut -d ' ' -f 1 | sort -u

Linux/UNIX 哲学吸引人的地方,大繁至简,一个命令只干一件事却能干到最好

代码语言:javascript复制
# 输出重复过的行(重复的只输出一个)及重复次数
$ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -dc
# 输出所有重复的行
$ history | cut -c 8- | cut -d ' ' -f 1 | sort | uniq -D

0 人点赞