sed全称为 ,行编辑器,同时也是一种流编辑器,它一次处理一行内容。

处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”( space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循环。

这样不断重复,直到文件末尾,文件内容并没有改变,除非使用重定向存储输出或-i。

格式如下:

sed -n '3p' /etc/passwd

sed-n_sed命令_sed

增删改查之查找

1)案例01:取出文件的第3行

sed -n '3p' /etc/passwd

2)案例02:取出/etc/的第2行到第5行

sed -n '2,5p' /etc/passwd

3)案例03:过滤出/etc/中包含root的行

grep 'root' /etc/passwd
[root@oldboy83-prod oldboy]# sed -n  '/root/p' /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
[root@oldboy83-prod oldboy]# 
[root@oldboy83-prod oldboy]# sed -n  '/^root/p' /etc/passwd
root:x:0:0:root:/root:/bin/bash

注意:sed进行过滤的时候需要使用//并且里面支持基础正则

如果需要使用扩展正则需要使用sed -r选项

4)案例04:获取范围内的日志

cat >/oldboy/sed.txt<<EOF
101,oldboy,CEO
102,bigbao,CTO
103,李导996,COO
104,yy,CFO
105,feixue,CIO
110,lidao,COCO
EOF

sed-n_sed_sed命令

试着取出.log过滤出11:05分到11:06分的日志

sed-n_sed命令_sed

5)sed命令过滤/查找功能小结

过滤的时候与grep类似支持正则表达式,sed -r支持扩展正则

sed可以指定行号,sed表示范围过滤

6)只显示第3行和第5行

sed-n_sed命令_sed

7)表示有规律的查找

[root@oldboy83-prod oldboy]# seq 10 |sed -n '1~2p'101,oldboy,CEO
1
3
5
7
9
[root@oldboy83-prod oldboy]# seq 10 |sed -n '2~2p'
2
4
6
8
10

增删改查之替换

1) 后向引用格式

==应用说明:==

sed命令中用于处理列的方式.

==使用格式:==

使用替换的形式 s###g

前2个井号之间通过正则+(),进行分组.

后面2个井号之间通过数字,获取前面分组的内容.

整体是后面调用前面分组的内容,称之为反向引用/后向引用.

sed-n_sed命令_sed

sed命令_sed-n_sed

2) 案例01: 调换/etc/第1列和最后一列内容

cp /etc/passwd  .

sed命令_sed-n_sed

sed命令_sed-n_sed

sed-n_sed_sed命令

输出最后结果:

sed命令_sed-n_sed

3) 案例02: 取出网卡ip地址

ip a  s eth0取出第3行里面的ip地址

方法01 
[root@oldboy83-prod oldboy]# ip a s  eth0 | sed -n '3p'  | sed -r 's#^.*et ([0-9.]+)/.*$#1#g'
10.0.0.200
方法02 进阶 
   sed -n '3p'
+
   sed -r 's#^.*et ([0-9.]+)/.*$#1#g'
-------------------------------
=  sed -nr '3  s#^.*et ([0-9.]+)/.*$#1#g  p'
方法03 awk 
[root@oldboy83-prod oldboy]# ip a s eth0 | sed -n '3p'  |awk '{print $2}' |sed 's#/24##g'
10.0.0.200
方法04  awk
[root@oldboy83-prod oldboy]# ip a s eth0 | sed -n '3p'  |awk -F "[ /]+" '{print $3}'
10.0.0.200
方法05-06 awk
ip a s eth0 | sed -n '3p'  |awk -F "[ /]+" '{print $3}'
[root@oldboy83-prod oldboy]# ip a s eth0 | awk -F "[ /]+" 'NR==3{print $3}'
10.0.0.200
方法07 
hostname -I

目前核心掌握第1种,awk后掌握awk方法

4) 案例03: 取出stat /etc/hosts中的0644或644

[root@oldboy83-prod oldboy]# stat /etc/hosts  |sed -n '4p' | sed -r 's#^.*(([0-9]+)/.*$#1#g'
0644

sed-n_sed_sed命令

增删改查之删除

sed  '3d' sed.txt
101,oldboy,CEO
102,oldbao,CTO
104,yy,CFO
105,feixue,CIO
110,oldboy,COCO

egrep  -v '^$|#'  /etc/ssh/sshd_config 
sed -r '/^$|#/d' /etc/ssh/sshd_config
awk  '!  /^$|#/' /etc/ssh/sshd_config

增删改查之增加

[root@oldboy83-prod oldboy]# cat sed.txt
101,oldboy,CEO
102,oldbao,CTO
103,李导996,COO
104,yy,CFO
105,feixue,CIO
110,oldboy,COCO
[root@oldboy83-prod oldboy]# sed '3a 999,lidao007,UFO' sed.txt
101,oldboy,CEO
102,oldbao,CTO
103,李导996,COO
999,lidao007,UFO
104,yy,CFO
105,feixue,CIO
110,oldboy,COCO
[root@oldboy83-prod oldboy]# sed '3i 999,lidao007,UFO' sed.txt
101,oldboy,CEO
102,oldbao,CTO
999,lidao007,UFO
103,李导996,COO
104,yy,CFO
105,feixue,CIO
110,oldboy,COCO
[root@oldboy83-prod oldboy]# sed '3c 999,lidao007,UFO' sed.txt
101,oldboy,CEO
102,oldbao,CTO
999,lidao007,UFO
104,yy,CFO
105,feixue,CIO
110,oldboy,COCO

———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666

声明:1、本内容转载于网络,版权归原作者所有!2、本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。3、本内容若侵犯到你的版权利益,请联系我们,会尽快给予删除处理!