管道是一种最基本的IPC机制,作用于有血缘关系的进程之间,完成数据传递。调用pipe系统函数即可创建一个管道,下面为大家详细讲解一下Linux管道命令。
站在用户的角度思考问题,与客户深入沟通,找到红寺堡网站设计与红寺堡网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站建设、做网站、企业官网、英文网站、手机端网站、网站推广、域名与空间、网页空间、企业邮箱。业务覆盖红寺堡地区。
管道命令使用|
作为界定符号,管道命令与上面说的连续执行命令不一样。
less,more,head,tail...都是可以接受standard input的命令,所以他们是管道命令
ls,cp,mv并不会接受standard input的命令,所以他们就不是管道命令了。
$ ls -al /etc | less
通过管道将ls -al
的输出作为 下一个命令less
的输入,方便浏览。
img
管道命令的处理图
cut -d '分隔字符' -f field // 用于分隔字符` `cut -c 字符范围` `[参数说明]` `-d : 后面接分隔字符,通常与 -f 一起使用` `-f : 根据-d 将信息分隔成数段,-f 后接数字 表示取出第几段` `-c : 以字符为单位取出固定字符区间的信息
栗子1:
打印/etc/passwd文件中以:为分隔符的第1个字段和第6个字段分别表示用户名和家目录
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | cut -d ':' -f 1,6
root:/root
bin:/bin
daemon:/sbin
adm:/var/adm
lp:/var/spool/lpd
...
栗子2:
打印/etc/passwd文件中每一行的前10个字符:
[root@izuf6i29flb2df231kt91hz /]# cat /etc/passwd | cut -c 1-10
root:x:0:0
bin:x:1:1:
daemon:x:2
adm:x:3:4:
lp:x:4:7:l
...
*ps:cut在处理多空格相连的数据时,比较吃力。*
grep [-acinv] [--color=auto] '查找字符串' filename` `[参数]` `-a : 将binary文件以text文件的方式查找数据` `-c : 计算找到 '查找字符串'的次数` `-i : 忽略大小写的不同` `-n : 输出行号` `-v : 反向选择,显示没有查找内容的行` `--color=auto : 将找到的关键字部分加上颜色显示
栗子3:
取出含有 fanco 的/etc/passwd文件的行
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | grep -n -c 'fanco'
1
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | grep -n 'fanco'
23:fanco:x:1001:1001::/home/fanco:/bin/bash
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | grep -n -v 'fanco'
1:root:x:0:0:root:/root:/bin/bash
2:bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
...
img
加上–color参数,好像不加默认也有颜色
sort
sort [-fbMnrtuk] [file or stdin]` `[参数]` `-f :忽略大小写的差异,例如A 与a 视为编码相同` `-b :忽略最前面的空格部分` `-M :以月份的名字来排序,例如JAN, DEC 等等的排序方法` `-n :使用『纯数字』进行排序默认是以文字型态来排序的)` `-r :反向排序` `-u :就是uniq ,相同的资料中,仅出现一行代表` `-t :分隔符号,预设是用[tab] 键来分隔` `-k :以那个区间(field) 来进行排序的意思
栗子4:
对/etc/passwd的账号进行排序
[root@izuf6i29flb2df231kt91hz /]# cat /etc/passwd | sort
adm:x:3:4:adm:/var/adm:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
...
通过/etc/passwd 第5列来进行排序
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | sort -t ':' -k 3
root:x:0:0:root:/root:/bin/bash
fanco:x:1001:1001::/home/fanco:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
bin:x:1:1:bin:/bin:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
这里排序还是按照文字进行排序的,切换成数字排序
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | sort -t ':' -k 3 -n
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
uniq [-ic]` `[参数]` `-i :忽略大小写的不同` `-c :进行计数
栗子5
使用 last 取出历史登录信息的账号,排序,去重
[root@izuf6i29flb2df231kt91hz /]# last | cut -d ' ' -f 1 | sort | uniq -c
1
7 reboot
19 root
1 wtmp
wc [-lwm]` `[参数]` `-l :仅列出行` `-w :仅列出多少字(英文单字)` `-m :多少字符
栗子6
查看etc/passwd中有多少账号
[root@izuf6i29flb2df231kt91hz /]# cat /etc/passwd | wc -l
23
计算最近登录系统的人次
[root@izuf6i29flb2df231kt91hz /]# last | grep [a-zA-Z] | grep -v 'wtmp' | wc -l
2
查看某个文件的行数 字数 字符数
[root@izuf6i29flb2df231kt91hz /]# cat etc/passwd | wc
23 32 997
tee:
在数据流的处理过程中将某段信息保存下来,使其既能输出到屏幕又能保存到某一个文件中。
img
tee的工作流程.png
tee [-a] file` `[参数]` `-a : 以累加的方式,将数据加入file中
栗子7
查询最近用户登录情况,并将其保存到文件中
[root@izuf6i29flb2df231kt91hz /]# last | tee info | cut -d ' ' -f 1
root
...
[root@izuf6i29flb2df231kt91hz /]# less info
root pts/0 112.28.181.159 Sun Jul 1 14:28 still logged in
root pts/0 112.28.181.159 Sun Jul 1 14:24 - 14:27 (00:03)
root pts/0 112.28.181.159 Sun Jul 1 13:19 - 14:24 (01:04)
root tty1 Sun Jul 1 12:46 still logged in
如果tee后接的文件已存在,内容会被覆盖掉,加上 -a参数则会累加
tr [-ds] set` `[参数]` `-d : 删除信息当中的set1这个字符串` `-s : 替换掉重复的字符
栗子8
将上一步生成的info 文件删除掉所有的 root
删除前
[root@izuf6i29flb2df231kt91hz /]# cat info
root pts/0 112.28.180.86 Thu May 10 18:01 - 18:12 (00:11)
reboot system boot 3.10.0-693.2.2.e Fri May 11 02:00 - 16:31 (51+14:30)
删除后
[root@izuf6i29flb2df231kt91hz /]# cat info | tr -d 'root'
ps/0 112.28.180.86 Thu May 10 18:01 - 18:12 (00:11)
eb sysem b 3.10.0-693.2.2.e Fi May 11 02:00 - 16:31 (51+14:30)
删除时并不是只删除连续的字符,reboot也被删除掉了root部分
除去dos文件留下来的^M符号
$ cat /root/passwd | tr -d '\r' > /root/passwd.linux
^M可以用\r替代
col [-xb]` `[参数]` `-x : 将tab键换成对等的空格键` `-b : 在文字内有反斜杠(/)时,仅保留反斜杠最后接的那个字符
img
栗子9
将上图中的^I换成空格键
[root@izuf6i29flb2df231kt91hz /]# cat info | col -x | cat -A | more
root pts/0 112.28.181.159 Sun Jul 1 14:28 still logged in$
col经常被用于将man page
转存为纯文本文件
join [-ti12] file1 file2` `[参数]` `-t : join 默认以空格符分隔数据,并且对比第一个字段的数据 ,如果两个文件相同,则将两条数据连成一行` `-i : 忽略大小写的差异` `-1 : 说明第一个文件通过那个字段来进行分析` `-2 : 说明第二个文件通过那个字段来分析
栗子10
将/etc/passwd 与 /etc/shadow 相关数据整合成一列
[root@izuf6i29flb2df231kt91hz /]# head -3 /etc/passwd /etc/shadow
==> /etc/passwd /etc/shadow $6$RNGEziM7$2e/EJd3hThS8TMqHSgDIfeDf7dJUG1dbJ0ik1goybGYmLGZL.sHNv1Ltb4.1HUksxTI0Cs3PJw5g/YirSImKg1:17643:0:99999:7:::
bin:*:17110:0:99999:7:::
daemon:*:17110:0:99999:7:::
[root@izuf6i29flb2df231kt91hz /]# join -t ':' /etc/passwd /etc/shadow
root:x:0:0:root:/root:/bin/bash:$6$RNGEziM7$2e/EJd3hThS8TMqHSgDIfeDf7dJUG1dbJ0ik1goybGYmLGZL.sHNv1Ltb4.1HUksxTI0Cs3PJw5g/YirSImKg1:17643:0:99999:7:::
bin:x:1:1:bin:/bin:/sbin/nologin:*:17110:0:99999:7:::
daemon:x:2:2:daemon:/sbin:/sbin/nologin:*:17110:0:99999:7:::
将etc/passwd 按:分隔的第4个字段 与 etc/group的第3个字段 比较,如果相同,则将他两同行数据放在一起
[root@izuf6i29flb2df231kt91hz /]# join -t ':' -1 4 /etc/passwd -2 3 /etc/group
0:root:x:0:root:/root:/bin/bash:root:x:
1:bin:x:1:bin:/bin:/sbin/nologin:bin:x:
2:daemon:x:2:daemon:/sbin:/sbin/nologin:daemon:x:
4:adm:x:3:adm:/var/adm:/sbin/nologin:adm:x:
join: /etc/passwd:6: is not sorted: sync:x:5:0:sync:/sbin:/bin/sync
7:lp:x:4:lp:/var/spool/lpd:/sbin/nologin:lp:x:
paste [-d] file1 file2` `[ 参数]` `-d : 后面可以接分隔字符,默认以[tab]来分隔的` `- : 如果file部分写成-,表示接受standard input数据的意思
栗子11
[root@izuf6i29flb2df231kt91hz /]# paste info info2
root pts/0 112.28.181.159 Sun Jul 1 14:28 still logged in root pts/0 112.28.181.159 Sun Jul 1 14:28 still logged in
root pts/0 112.28.181.159 Sun Jul 1 14:24 - 14:27 (00:03) root pts/0 112.28.181.159 Sun Jul 1 14:24 - 14:27 (00:03)
root pts/0 112.28.181.159 Sun Jul 1 13:19 - 14:24 (01:04) root pts/0 112.28.181.159 Sun Jul 1 13:19 - 14:24 (01:04)
expand [-t] file
[参数]
“ -t : 后面接数字,一般,一个tab可以用8个空格代替,可以自行定义代表几个空格
栗子12
[root@izuf6i29flb2df231kt91hz /]# cat info | expand -3 info
root pts/0 112.28.181.159 Sun Jul 1 14:28 still logged in
root pts/0 112.28.181.159 Sun Jul 1 14:24 - 14:27 (00:03)
root pts/0 112.28.181.159 Sun Jul 1 13:19 - 14:24 (01:04)
root tty1 Sun Jul 1 12:46 still logged in
split:顾名思义,讲一个大文件依据文件大小或行数切割成为小文件
split [-bl] file prefix` `[参数]` `-b : 后面可接欲切割文件的大小,可加单位,例如b,k,m等` `-l : 以行数来进行切割` `PREFIX : 代表前导符,可作为切割文件的前导文字
栗子
$ split -b 300K /etc/passwd
将ls -al输出文件 按10行分成一个新的文件
[root@izuf6i29flb2df231kt91hz /]# ls -al / | split -l 10 - lsrrot
[root@izuf6i29flb2df231kt91hz /]# ls
b boot dev home info2 lib64 lsrrotaa lsrrotac mnt opt root sbin sys usr
bin c etc info lib lost+found lsrrotab media n proc run srv tmp var
[root@izuf6i29flb2df231kt91hz /]# cd /
[root@izuf6i29flb2df231kt91hz /]# ls
b boot dev home info2 lib64 lsrrotaa lsrrotac mnt opt root sbin sys usr
bin c etc info lib lost+found lsrrotab media n proc run srv tmp var
[root@izuf6i29flb2df231kt91hz /]# wc -l lsrrot*
10 lsrrotaa
10 lsrrotab
9 lsrrotac
29 total
网站标题:详解Linux 管道命令
当前路径:http://www.mswzjz.cn/qtweb/news12/155012.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能