码迷,mamicode.com
首页 > 其他好文 > 详细

awk工具

时间:2018-01-18 10:14:07      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:分隔符   输出   文档   打印   执行   定义   ash   alt   大于   

awk工具

作用:针对文档中的行进行操作,截取功能;针对文档中的行来操作,一行一行的执行;

打印文件

awk ‘{print $0}‘ test.txt

截取文档中的某个段
head -n2 passwd.txt | awk -F ‘:‘ ‘{print $1}‘
显示passwd.txt 2行 | 截取以:为分隔符的前面1段
-F作用是指定分隔符,默认为空格或者tab;
$1 为第一段 $2为第二段 $0为全部

[root@shu-test sed]# head -n2 test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
[root@shu-test sed]# head -n2 test.txt |awk -F ‘:‘ ‘{print $1}‘
root
bin
[root@shu-test sed]#
[root@shu-test sed]# head -n2 test.txt |awk -F ‘:‘ ‘{print $1,$2,$3}‘
root x 0
bin x 1
[root@shu-test sed]#

匹配字符或字符串

awk ‘/oo/‘ test.txt
匹配test.txt中字符oo

[root@shu-test sed]# awk ‘/oo/‘ test.txt
root:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
[root@shu-test sed]#

awk -F ‘:‘ ‘$1 ~/oo/‘ test.txt
匹配test.txt中第一段中带有oo的;中间~为匹配意思

[root@shu-test sed]# awk -F ‘:‘ ‘$1~/oo/‘ test.txt
root:x:0:0:root:/root:/bin/bash
[root@shu-test sed]#

awk -F ‘:‘ ‘/root/ {print $1,$3} /user/ {print $1,$3}‘ test.txt
匹配带有root的行 并打印此行第一段与第三段,并再匹配user,打印第一段与第三段;

[root@shu-test sed]# awk -F ‘:‘ ‘/root/ {print $1,$3} /user/ {print $1,$3}‘ test.txt
root 0
operator 11
user01 1000
user02 1001
user005 1008
user007 1007
[root@shu-test sed]#

条件操作符

(== 、> 、>= 、< 、<= 、!=)并且 或者(&& ||)
awk -F ‘:‘ ‘$3=="0"‘ test.txt
将test.txt中意:为分隔符的第三段‘等于’0的行打印出来,双引号为字符串,不加双引号为数字;

[root@shu-test sed]# awk -F ‘:‘ ‘$3=="0"‘ test.txt
root:x:0:0:root:/root:/bin/bash
[root@shu-test sed]# awk -F ‘:‘ ‘$3=="1008"‘ test.txt
user005:x:1008:1005::/home/user005:/bin/bash
[root@shu-test sed]#
[root@shu-test sed]# awk -F ‘:‘ ‘$3>=1000 {print $1}‘ test.txt
user01
user02
user005
user007

awk的内置变量

-F 定义分隔符,OFS输出时定义一个分隔符,NF表示用分隔符分隔后一共有多少段,NR表示行号,NF段;

head -5 test.txt |awk -F ‘:‘ ‘{OFS="#"} {print $1,$3,$4}‘
打印前5行中以分隔符:为定义的第134段,并在输出的134段中加上分隔符#

[root@shu-test sed]# head -5 test.txt |awk -F ‘:‘ ‘{OFS="#"} {print $1,$3,$4}‘
root#0#0
bin#1#1
daemon#2#2
adm#3#4
lp#4#7
[root@shu-test sed]#

awk -F ‘:‘ ‘{OFS="#"} {if($3>500){print $1,$2,$3,$4}}‘ test.txt
增加判断语句如果第三段大于500才会输出1 2 3 4 段

[root@shu-test sed]# awk -F ‘:‘ ‘{OFS="#"} {if($3>500){print $1,$2,$3,$4}}‘ test.txt
polkitd#x#999#997
chrony#x#998#996
user01#x#1000#1000
user02#x#1001#1001
user005#x#1008#1005
user007#x#1007#1005
[root@shu-test sed]#

以行号显示

[root@shu-test sed]# head -5 test.txt|awk -F ‘:‘ ‘{print NR":"$0}‘
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:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
[root@shu-test sed]#

打印前十行

[root@shu-test sed]# awk -F ‘:‘ ‘NR<=10‘ test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
[root@shu-test sed]#

awk中的数学运算

head -n2 test.txt |awk -F ‘:‘ ‘{$7=$3+$4;print $0}‘
第七段=第三段+第四段的 将所在行输出
0=0+0 2=1+1

[root@shu-test sed]# head -n2 test.txt |awk -F ‘:‘ ‘{$7=$3+$4;print $0}‘
root x 0 0 root /root 0
bin x 1 1 bin /bin 2
[root@shu-test sed]#

awk工具

标签:分隔符   输出   文档   打印   执行   定义   ash   alt   大于   

原文地址:http://blog.51cto.com/shuzonglu/2062289

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!