昨天回顾
- 使用grep命令取IP地址
[root@oldboy63 ~]# ip a s eth0|grep 'inet '|egrep -o '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}'
10.0.0.200
10.0.0.255
[root@oldboy63 ~]# ip a s eth0|grep 'inet '|egrep -o '([0-9]{1,3}\.?){4}'
10.0.0.200
10.0.0.255
[root@oldboy63 ~]# ip a s eth0|grep 'inet '|egrep -o '([0-9]{1,3}\.*){4}'
10.0.0.200
10.0.0.255
[root@oldboy63 ~]# ip a s eth0|grep 'inet '|egrep -o '([0-9]{1,3}\.?){4}'|head -1
10.0.0.200
今日总结
-
sed执行原理
sed [参数] '条件指令' 文件信息
- sed操作增,删,改,查
测试文档
[root@oldboy63 ~]# cat person.txt
101,oldboy,CEO
102,zhaoyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
sed增加操作
a在匹配信息下方添加
i 在匹配信息上方添加
i 的用法,在每一行上方插入oldboy
[root@oldboy63 ~]# sed 'ioldboy' person.txt 因为sed是逐行匹配,所以直接添加就可以
oldboy
101,oldboy,CEO
oldboy
102,zhaoyao,CTO
oldboy
103,Alex,COO
oldboy
104,yy,CFO
oldboy
105,feixue,CI
2)分别在第四行和第二行下方插入oldboy和oldgirl
[root@oldboy63 ~]# sed -e '4aoldboy' -e '2aoldgirl' person.txt
101,oldboy,CEO
102,zhaoyao,CTO
oldgirl
103,Alex,COO
104,yy,CFO
oldboy
105,feixue,CIO
删
d 删除
d显示偶数行,1~2应是奇数行,d删除奇数行
[root@oldboy63 ~]# sed '1~2d' person.txt
102,zhaoyao,CTO
104,yy,CFO
删除包含CTO和CIO的信息
[root@oldboy63 ~]# sed -r '/CTO|CIO/d' person.txt 使用了扩展正则进行匹配
101,oldboy,CEO
103,Alex,COO
104,yy,CFO
改
c 改变某一行内容
s###g 替换,改变
i 直接修改文本内容
c:把第五行改成oldboy
[root@oldboy63 ~]# sed '5coldboy' person.txt
101,oldboy,CEO
102,zhaoyao,CTO
103,Alex,COO
104,yy,CFO
oldboy
i:直接修改文件内容把CIO改成CCC
[root@oldboy63 ~]# sed -i 's#CIO#CCC#g' person.txt
[root@oldboy63 ~]# cat person.txt
101,oldboy,CEO
102,zhaoyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CCC
注:sed –i参数不能和-n一起使用,因为-i是修改模式空间的内容到文件,-n直接把默认输出到模式空间的内容取消掉,只显示p打印的内容
[root@oldboy63 ~]# sed -ni 's#CIO#CCC#g' person.txt
[root@oldboy63 ~]# cat person.txt 什么都没有了
sed –i参数只能放在最后面,当于别的参数一起使用时.它也可以当做备份使用
[root@oldboy63 ~]# sed -in 's#CIO#CCC#g' person.txt
[root@oldboy63 ~]# ls
2 anaconda-ks.cfg oldboy person.txt person.txtn test
[root@oldboy63 ~]# cat person.txt
101,oldboy,CEO
102,zhaoyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CCC
[root@oldboy63 ~]# cat person.txtn
101,oldboy,CEO
102,zhaoyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
查
查找第二行
[root@oldboy63 ~]# sed -n '2p' person.txt
102,zhaoyao,CTO
查找奇数行
[root@oldboy63 ~]# sed -n '1~2p' person.txt
101,oldboy,CEO
103,Alex,COO
105,feixue,CCC
[root@oldboy63 ~]# sed 'n;d' person.txt n是读取模式空间的下一行的内容,追加覆盖前一行,并标准输出
101,oldboy,CEO
103,Alex,COO
105,feixue,CCC
[root@oldboy63
查找包含oldboy和feixue的行
[root@oldboy63 ~]# sed -nr '/oldboy|feixue/p' person.txt
101,oldboy,CEO
105,feixue,CCC
取ip
hostname –I
[root@oldboy63 ~/oldboy]# hostname -I
10.0.0.200
2.2 grep 取IP
[root@oldboy63 ~/oldboy]# ip a s eth0|grep 'inet '|egrep -o '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}'|head -1
10.0.0.200
[root@oldboy63 ~/oldboy]# ip a s eth0|grep 'inet '|egrep -o '([0-9]{1,3}\.?){4}' |head -1
10.0.0.200
[root@oldboy63 ~/oldboy]# ip a s eth0|grep 'inet '|egrep -o '([0-9]{1,3}\.*){4}' |head -1
10.0.0.200
注: egrep -o '([0-9]{1,3}\.?){4}' 因为第一个匹配[0-9]{1,3}\.已经重复匹配了三次,因此可以使用()括起来整体匹配,最后一位只匹配[0-9]{1,3}因此可以让\.使用?匹配前面的.0次或1次,用来执行
2.3 sed 取IP
[root@oldboy63 ~/oldboy]# ip a s eth0|sed -nr '/inet /s#.*t (.*)/[0-9]{1,3} b.*#\1#gp'
10.0.0.200
sed取文件权限数值
[root@oldboy63 ~/oldboy]# stat /etc/hosts
File: ‘/etc/hosts’
Size: 179 Blocks: 8 IO Block: 4096 regular file
Device: 803h/2051d Inode: 16810598 Links: 2
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2019-07-23 16:41:34.907531263 +0800
Modify: 2019-07-17 19:38:16.053197563 +0800
Change: 2019-07-23 15:02:04.337817135 +0800
Birth: -
[root@oldboy63 ~/oldboy]# stat /etc/hosts|sed -nr '4s#.* \((.*)/-.*#\1#gp'
0644
注:错误示例
[root@oldboy63 ~/oldboy]# stat /etc/hosts|sed -nr '4s#.* \((.*)/.*#\1#gp'
0
sed改文件名
[root@oldboy63 ~/oldboy]# ls
10.jpg 1.jpg 2.jpg 3.jpg 4.jpg 5.jpg 6.jpg 7.jpg 8.jpg 9.jpg
[root@oldboy63 ~/oldboy]# ls |xargs -n 1|sed -r 's#([0-9]+)\.jpg#mv & \1.txt#g'|bash
[root@oldboy63 ~/oldboy]# ls
10.txt 1.txt 2.txt 3.txt 4.txt 5.txt 6.txt 7.txt 8.txt 9.txt