awk 练习题-01

发布于 2018-01-30  552 次阅读


把/etc/passwd 复制到/root/test.txt,用 awk 打印整个 test.txt (以下操作都是用 awk 工具实现,针对 test.txt)
[root@am-01:~#] awk '{print $0}' 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
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
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
aming:x:1000:1000::/home/aming:/bin/bash
ntp:x:38:38::/etc/ntp:/sbin/nologin
user1:x:1001:1001::/home/user1:/bin/bash
user2:x:1002:1002::/home/user2:/bin/bash
user3:x:1003:1005::/home/user3:/bin/bash
user4:x:1004:1005::/home/aming111:/sbin/nologin
user5:x:1005:1006::/home/user5:/bin/bash
user6:x:1007:1007::/home/user6:/bin/bash
查找所有包含 'bash' 的行
[root@am-01:~#] awk '/bash/' test.txt
root:x:0:0:root:/root:/bin/bash
aming:x:1000:1000::/home/aming:/bin/bash
user1:x:1001:1001::/home/user1:/bin/bash
user2:x:1002:1002::/home/user2:/bin/bash
user3:x:1003:1005::/home/user3:/bin/bash
user5:x:1005:1006::/home/user5:/bin/bash
user6:x:1007:1007::/home/user6:/bin/bash
用 ':' 作为分隔符,查找第三段等于 0 的行
[root@am-01:~#] awk -F ':' '$3==0' test.txt
root:x:0:0:root:/root:/bin/bash
用 ':' 作为分隔符,查找第一段为 'root' 的行,并把该段的 'root' 换成 'toor' (可以连同 sed 一起使用)
[root@am-01:~#] awk -F ':' '$1=="root"' test.txt | sed 's/root/toor/g'
toor:x:0:0:toor:/toor:/bin/bash
用 ':' 作为分隔符,打印最后一段
[root@am-01:~#] awk -F ':' '{print $NF}' test.txt
/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
/sbin/nologin
/bin/bash
/bin/bash
/bin/bash
/sbin/nologin
/bin/bash
/bin/bash
打印行数大于 20 的所有行
[root@am-01:~#] awk -F ':' 'NR>=20' test.txt
aming:x:1000:1000::/home/aming:/bin/bash
ntp:x:38:38::/etc/ntp:/sbin/nologin
user1:x:1001:1001::/home/user1:/bin/bash
user2:x:1002:1002::/home/user2:/bin/bash
user3:x:1003:1005::/home/user3:/bin/bash
user4:x:1004:1005::/home/aming111:/sbin/nologin
user5:x:1005:1006::/home/user5:/bin/bash
user6:x:1007:1007::/home/user6:/bin/bash
用 ':' 作为分隔符,打印所有第三段小于第四段的行
[root@am-01:~#] awk -F ':' '$3<$4' test.txt
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
user3:x:1003:1005::/home/user3:/bin/bash
user4:x:1004:1005::/home/aming111:/sbin/nologin
user5:x:1005:1006::/home/user5:/bin/bash
用 ':' 作为分隔符,打印第一段以及最后一段,并且中间用 '@' 连接 (例如,第一行应该是这样的形式 'root@/bin/bash' )
[root@am-01:~#] awk -F ':' '{OFS="@"} {print $1,$NF}' test.txt
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
avahi-autoipd@/sbin/nologin
dbus@/sbin/nologin
polkitd@/sbin/nologin
tss@/sbin/nologin
postfix@/sbin/nologin
sshd@/sbin/nologin
aming@/bin/bash
ntp@/sbin/nologin
user1@/bin/bash
user2@/bin/bash
user3@/bin/bash
user4@/sbin/nologin
user5@/bin/bash
user6@/bin/bash
用 ':' 作为分隔符,把整个文档的第四段相加,求和
[root@am-01:~#] awk -F ':' '{(tot=tot+$4)};END{print tot}' test.txt
8810