[root@hadoop01 root]$ nl passwd | sed '2a hadoop' 1 root:x:0:0:root:/root:/bin/bash 2 bin:x:1:1:bin:/bin:/sbin/nologin hadoop 3 daemon:x:2:2:daemon:/sbin:/sbin/nologin 2.4 在第二行前 [root@hadoop01 root]$ nl passwd | sed '2i hadoop' 1 root:x:0:0:root:/root:/bin/bash hadoop 2 bin:x:1:1:bin:/bin:/sbin/nologin 3 daemon:x:2:2:daemon:/sbin:/sbin/nologin2.5 增加两行以上,在第二行后面加入两行字 [root@hadoop01 root]$ nl passwd | sed '2a hadoop > scala' 1 root:x:0:0:root:/root:/bin/bash 2 bin:x:1:1:bin:/bin:/sbin/nologin hadoop scala 3 daemon:x:2:2:daemon:/sbin:/sbin/nologin 每一行之间都必须要以反斜杠『』来进行新行的添加喔!所以,上面的例子中,我们可以发现在第一行的最后面就有存在 。
3、以行为单位的替换与显示3.1 将第2-5行的内容取代成为『hello world』 [root@hadoop01 root]$ nl passwd | sed '2,5c hello world' 1 root:x:0:0:root:/root:/bin/bash hello world 6 ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin 4、数据的搜寻并显示4.1 root关键字的行 [root@hadoop01 root]$ nl passwd | sed '/root/p' 1 root:x:0:0:root:/root:/bin/bash 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 halt:x:7:0:halt:/sbin:/sbin/halt 5 mail:x:8:12:mail:/var/spool/mail:/sbin/nologin 6 ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin 7 nobody:x:99:99:Nobody:/:/sbin/nologin 8 sssd:x:997:995:User for sssd:/:/sbin/nologin 9 polkitd:x:996:994:User for polkitd:/:/sbin/nologin 10 apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin 11 abrt:x:173:173::/etc/abrt:/sbin/nologin 12 rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin 13 unbound:x:994:992:Unbound DNS resolver:/etc/unbound:/sbin/nologin 14 memcached:x:993:991:Memcached daemon:/run/memcached:/sbin/nologin 15 rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin如果root找到,除了输出所有行,还会输出匹配行 。
使用-n的时候将只打印包含模板的行 。
[root@hadoop01 root]$ nl passwd | sed -n '/root/p' 1 root:x:0:0:root:/root:/bin/bash5、数据的搜寻并删除5.1 删除/passwd所有包含root的行,其他行输出 [root@hadoop01 root]$ nl passwd | sed '/root/d' 2 bin:x:1:1:bin:/bin:/sbin/nologin6、数据的搜寻并执行命令6.1 搜索passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把root替换为hadoop,再输出这行:
- p:打印所有的;
- q:打印匹配的
[root@hadoop01 root]$ nl passwd | sed '/root/{s/root/hadoop/;p;q;}' 1 hadoop:x:0:0:root:/root:/bin/bash 1 hadoop:x:0:0:root:/root:/bin/bash [root@hadoop01 root]$ nl passwd | sed '/root/{s/root/hadoop/;p}' 1 hadoop:x:0:0:root:/root:/bin/bash 1 hadoop: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 ...7、数据的搜寻并替换除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代 。基本上 sed 的搜寻与替代的与 vi 相当的类似 sed 's/要被取代的字串/新的字串/g'7.0 只要第一行的数字部分 [root@hadoop01 root]$ nl passwd | sed -n '/root/p' 1 root:x:0:0:root:/root:/bin/bash7.1 删除第一行,数字前半部分 [root@hadoop01 root]$ nl passwd | sed -n '/root/p' | sed 's/^.*x://g' 0:0:root:/root:/bin/bashs/后面的字符串是包含的关系7.2 删除第一行,数字后半部分
[root@hadoop01 root]$ nl passwd | sed -n '/root/p' | sed 's/^.*x://g' | sed 's/:root.*$//g' 0:08、多点编辑8.1 一条sed命令,删除passwd第四行到末尾的数据,并把root替换为hadoop [root@hadoop01 root]$ nl passwd | sed -e '4,$d' 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 [root@hadoop01 root]$ nl passwd | sed -e '4,$d' -e 's/sbin/hadoop/g' 1 root:x:0:0:root:/root:/bin/bash 2 bin:x:1:1:bin:/bin:/hadoop/nologin 3 daemon:x:2:2:daemon:/hadoop:/hadoop/nologin
推荐阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- SQLSERVER也能部署在linux环境?SQLServer2019在CENTOS7部署详解
- node是什么?如何在linux下安装node?
- Linux netstat命令详解
- 从Linux源码角度看Epoll,透过现象看本质
- Linux eBPF解析
- linux 国产操作系统deepin系统从安装到惊喜
- linux服务器垃圾清理记
- 2021 专业人士 Linux 系统 TOP 5
- linux中的makefile编写规则
- Linux服务器打造一个简单的文件共享系统
