linux正则表达式企业级深度实践案例1

linux正则表达式结合三剑客企业级实践:

1、取系统ip

[root@redhat~]#  ifconfig  eth0

解答:

替换命令:

sed  's#支持正则位置##g'  file

先取第2行:

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2p '

inet  addr:192.168.31.135     Bcast:192.168.31.255     Mask:255.255.255.0

^ .*匹配,如果不给目标前的固定结尾就会匹配到行尾,结果就匹配一行

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2p ' | sed  ' s#^ .*##g '

 

对目标前的内容匹配替换:

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2p ' | sed  ' s#^ .*dr :##g '

192.168.31.135     Bcast:192.168.31.255     Mask:255.255.255.0

对目标后的内容匹配替换:

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2p ' | sed  ' s#^ .*dr :##g ' | sed  ' s#B.*$##g '

192.168.31.135  <==这里结尾有两个空格

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2p ' | sed  ' s#^ .*dr :##g ' | sed  ' s#        B.*$##g '

192.168.31.135  <==这里结尾无空格

 

sed  -n  's#支持正则位置##gp'  file

 

inet  addr:192.168.31.135  Bcast:192.168.31.255  Mask:255.255.255.0

处理技巧:

匹配需要的目标(获取的字符串如上文的ip)前的字符串一般用以..开头(^.*)来匹配开头,匹配的结尾写上实际的字符,

如:  " ^.*addr: " 表达式就匹配 "    inet  addr: "  ,而处理需要的目标后的内容一般在匹配的开头写上实际的字符,而结尾是用以...结尾(.*$)来匹配。如:Bcast: .*$ 部分表示匹配 "Bcast: 192.168.31.255  Mask:255.255.255.0"。

 

方法2:

替换命令1:

sed  -nr  ' s#支持正则位置##gp '  file

指定行号:s前的2为行号

sed  -nr  ' 2s#支持正则位置##gp '  file

解答:

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' s#^ .*adrr :##g ' | sed  -n  ' s#  Bc.*$##gp '

192.168.31.135

[root@redhat~]#  ifconfig  eth0 | sed  -n  ' 2s#^ .*adrr :##g ' | sed  -n  ' s#  Bc.*$##gp '

192.168.31.135

 

sed的后向引用:

sed  -n  ' s#() ()#\1\2#gp '  file

当在前面匹配部分用小括号的时候,第一个括号内容,可以在后面部分用\1输出。

第一个括号内容,可以在后面部分用\2输出。

[root@redhat~]#  echo  I  am  redhat  linux.  >a.txt

[root@redhat~]#  cat  a.tet

I  am  redhat  linux.

[root@redhat~]#  sed  -n  ' s#^ .*m  ##gp '  a.txt

redhat  linux.

[root@redhat~]#  sed  -nr  ' s#^ .*m  (.*)  l.*$#\l#gp '  a.tet

redhat

 

 

[root@redhat~]#  ifconfig  eth0 | sed  -nr  ' s#^ .*dr:(.*)  B.*$#\l#gp '

 

posted @ 2018-09-03 16:00  axzq  阅读(340)  评论(1编辑  收藏  举报