【2018.04.29学习笔记】【awk练习题】

awk练习题

test原文件内容:

[root@lgs-01 awk]# cat test 
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
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:997:User for polkitd:/:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
lgs:x:1008:1000::/home/lgs:/bin/bash
abc:x:1001:1000::/home/abc:/bin/bash
12:22:55
587:1
12:21
2:2:1:fsfs:root:/bin/:/user
342:x:3d:fafa:toor:/user:/bin
xx:xx:xx:xx:xx:xx:34
rr:rr:rr:rr:rr:rr:t55abc
##:#34#:bb:bb:bb:%pp^:$!#
#234#:vv:vv:vv:vv:ds:@user#

1、用awk 打印整个test (以下操作都是用awk工具实现,针对test)

答案:awk -F ':' '{print $0}' test
[root@lgs-01 awk]# awk -F ':' '{print $0}' test
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
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:997:User for polkitd:/:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
lgs:x:1008:1000::/home/lgs:/bin/bash
abc:x:1001:1000::/home/abc:/bin/bash
12:22:55
587:1
12:21
2:2:1:fsfs:root:/bin/:/user
342:x:3d:fafa:toor:/user:/bin
xx:xx:xx:xx:xx:xx:34
rr:rr:rr:rr:rr:rr:t55abc
##:#34#:bb:bb:bb:%pp^:$!#
#234#:vv:vv:vv:vv:ds:@user#

2、查找所有包含 ‘bash’ 的行

答案:awk -F ':' '$0 ~ /bash/' test
[root@lgs-01 awk]# awk -F ':' '$0 ~ /bash/' test
root:x:0:0:root:/root:/bin/bash
lgs:x:1008:1000::/home/lgs:/bin/bash
abc:x:1001:1000::/home/abc:/bin/bash

3、用 ‘:’ 作为分隔符,查找第三段等于0的行

答案:awk -F ':' '$3=="0" {print $0}' test
[root@lgs-01 awk]# awk -F ':' '$3=="0" {print $0}' test
root:x:0:0:root:/root:/bin/bash

4、用 ‘:’ 作为分隔符,查找第一段为 ‘root’ 的行,并把该段的 ‘root’ 换成 ‘toor’ (可以连同sed一起使用)

答案:awk -F ':' '$1=="root" {print $0}' test|sed -r 's/root/toor/g'
[root@lgs-01 awk]# awk -F ':' '$1=="root" {print $0}' test|sed -r 's/root/toor/g'
toor:x:0:0:toor:/toor:/bin/bash

5、用 ‘:’ 作为分隔符,打印最后一段

答案:awk -F ':' '{print $NF}' test
[root@lgs-01 awk]# awk -F ':' '{print $NF}' test
/bin/bash
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/bin/sync
/sbin/shutdown
/sbin/halt
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/sbin/nologin
/bin/bash
/bin/bash
55
1
21
/user
/bin
34
t55abc
$!#
@user#

6、打印行数大于20的所有行

答案:awk -F ':' 'NR>20 {print $0}' test
[root@lgs-01 awk]# awk -F ':' 'NR>20 {print $0}' test
abc:x:1001:1000::/home/abc:/bin/bash
12:22:55
587:1
12:21
2:2:1:fsfs:root:/bin/:/user
342:x:3d:fafa:toor:/user:/bin
xx:xx:xx:xx:xx:xx:34
rr:rr:rr:rr:rr:rr:t55abc
##:#34#:bb:bb:bb:%pp^:$!#
#234#:vv:vv:vv:vv:ds:@user#

7、用 ‘:’ 作为分隔符,打印所有第三段小于第四段的行

答案:awk -F ':' '$3<$4 {print $0}' test
[root@lgs-01 awk]# awk -F ':' '$3<$4 {print $0}' test
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
2:2:1:fsfs:root:/bin/:/user
342:x:3d:fafa:toor:/user:/bin

8、用 ‘:’ 作为分隔符,打印第一段以及最后一段,并且中间用 ‘@’ 连接 (例如,第一行应该是这样的形式 'root@/bin/bash‘ )

答案:awk -F ':' '{print$1"@"$NF}' test
[root@lgs-01 awk]# awk -F ':' '{print$1"@"$NF}' test
root@/bin/bash
bin@/sbin/nologin
daemon@/sbin/nologin
adm@/sbin/nologin
lp@/sbin/nologin
sync@/bin/sync
shutdown@/sbin/shutdown
halt@/sbin/halt
mail@/sbin/nologin
operator@/sbin/nologin
games@/sbin/nologin
ftp@/sbin/nologin
nobody@/sbin/nologin
systemd-network@/sbin/nologin
dbus@/sbin/nologin
polkitd@/sbin/nologin
postfix@/sbin/nologin
sshd@/sbin/nologin
chrony@/sbin/nologin
lgs@/bin/bash
abc@/bin/bash
12@55
587@1
12@21
2@/user
342@/bin
xx@34
rr@t55abc
##@$!#
#234#@@user#

9、用 ‘:’ 作为分隔符,把整个文档的第四段相加,求和

答案:awk -F ':' '{(sum=sum+$4)};END{print sum}' test
[root@lgs-01 awk]# awk -F ':' '{(sum=sum+$4)};END{print sum}' test
4704

猜你喜欢

转载自my.oschina.net/u/3804114/blog/1803414
今日推荐