# BEGIN这是处理数据以前运行的脚本 BEGIN { # 这是定义的变量,在如下其余阶段的脚本中也能够调用,变量的调用方式如同shell中调用变量,可是不加$符号 separator1=" " FS=":" print "用户名"separator1"密码"separator1"用户ID"separator1"组ID"separator1"用户全名"separator1"主目录"separator1"登陆shell"separator1} # 这是进行数据处理的脚本 { print $1 separator1 $2 separator1 $3 separator1 $4 separator1 $5 separator1 $6 separator1 $7 separator1 } # END这是数据处理最后要运行的脚本 END { print "==========================THE END=======================" }
指定方式为:node
root@node1:~# gawk -f ./passwd.awk /etc/passwd
为了防止与某些特定的字符相冲突,sed支持选择其余的字符进行分隔shell
sed 's!/bin/bash!/bin/csh' /etc/passwd
行寻址的使用格式bash
[address]command
也能够把特定地址的多个命令放在一块儿app
address{ command1 command2 command3 }
sed '2s/dog/cat/' data1' sed '2,21s/dog/cat/' data1' sed '2,$s/dog/cat/' data1'
sed '/admin/s/dog/cat' data2
root@node1:~# sed -n '2{s/daemon/admin/g;s/nologin/login/p}' /etc/passwd admin:x:1:1:admin:/usr/sbin:/usr/sbin/login
sed 'd' data2 #删除data2中的全部记录 sed '3d' data2 #删除data2中第三行 sed '4,$d' data2 #删除data2中第四行到最后的数据 sed '/line 1/d' data2 #删除模式匹配到的行 sed '/1/,/2/d' data2 #匹配到第一个打开行删除功能,匹配到第二个执行行删除功能,并删除两个匹配到的行,若是第二个模式没有被匹配到,那么整个文件的数据都被删掉了
i
在指定行前插入一个新行a
在指定行后插入一个新行root@node1:~# echo "line" | sed 'i\linedemo' linedemo line root@node1:~# echo "line" | sed 'a\linedemo' line linedemo
可是在数据流中须要指定要插入或者要追加的位置ide
root@node1:~# cat date2 line1 line2 line3 root@node1:~# sed '1i\demo' date2 demo line1 line2 line3 root@node1:~# sed '2a\demo' date2 line1 line2 demo line3 # sed '1i\first line' date2 # 老是插入在第一行 # sed '$a\end line' date2 # 老是追加在最后一行
root@node1:~# sed '3c\the change line' date2 line1 line2 the change line root@node1:~# sed '1,$c\the change line' date2 the change line root@node1:~# sed '1,2c\the change line' date2 the change line line3 root@node1:~# sed '/line1/c\the change line' date2 the change line line2 line3
# 前面的数字与后面的字母一对一的进行转换,1映射到a root@node1:~# sed 'y/123/abc/' date2 linea lineb linec root@node1:~# sed '1,2y/123/abc/' date2 linea lineb line3
打印文本行大数据
root@node1:~# head -3 /etc/passwd | sed 'p' root:x:0:0:root:/root:/bin/bash root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin bin:x:2:2:bin:/bin:/usr/sbin/nologin bin:x:2:2:bin:/bin:/usr/sbin/nologin root@node1:~# head -3 /etc/passwd | sed -n 'p' root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin bin:x:2:2:bin:/bin:/usr/sbin/nologin
打印行号3d
root@node1:~# head -3 /etc/passwd | sed -n '=' 1 2 3 root@node1:~# head -3 /etc/passwd | sed '=' 1 root:x:0:0:root:/root:/bin/bash 2 daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin 3 bin:x:2:2:bin:/bin:/usr/sbin/nologin
列出行code
# 注意每行最后的一个$字符 root@node1:~# head -3 /etc/passwd | sed -n 'l' root:x:0:0:root:/root:/bin/bash$ daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin$ bin:x:2:2:bin:/bin:/usr/sbin/nologin$