[root@adai003 grep]# sed -n '1,10 {/oo/p}' test.txt
root:x:0:0:root:/root:/bin/bash
3233:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
[root@adai003 grep]# head -n5 test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
234:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
3233:x:4:7:lp:/var/spool/lpd:/sbin/nologin
[root@adai003 grep]# sed '/daemon/{p; :a; N; $!ba; d}' test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
234:x:2:2:daemon:/sbin:/sbin/nologin
解析:定义一个标签a,匹配c,然后N把下一行加到模式空间里,匹配最后一行时,才退出标签循环,然后命令d,把这个模式空间里的内容全部清除。
[root@adai003 grep]# sed -n '/daemon/{N;p}' test.txt
234:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
[root@adai003 grep]# sed 's/\(.*nologin.*\)/& 8/' test.txt |head -n3
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin 8
234:x:2:2:daemon:/sbin:/sbin/nologin 8
解析: “.nologin.” 代表nologin所在的行,()是定义其为一个整体。
1、切换单词首字母大小写
[root@adai003 grep]# sed 's/\b[a-z]/\u&/g' test.txt |head -n3
Root:X:0:0:Root:/Root:/Bin/Bash
Bin:X:1:1:Bin:/Bin:/Sbin/Nologin
234:X:2:2:Daemon:/Sbin:/Sbin/Nologin
2、切换所有字母大小写
[root@adai003 grep]# sed 's/[a-z]/\u&/g' test.txt |head -n3
ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH
BIN:X:1:1:BIN:/BIN:/SBIN/NOLOGIN
234:X:2:2:DAEMON:/SBIN:/SBIN/NOLOGIN
解析: sed中,使用\u表示大写,\l表示小写,\b表示单词首字母
[root@adai003 grep]# sed -n '/^root/,/daemon/p' test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
234:x:2:2:daemon:/sbin:/sbin/nologin
解析:打印以root开头的行和daemon所在行之间的内容。
(adsbygoogle = window.adsbygoogle || []).push({});