awk練習題

  1. 用awk 打印整個test.txt (如下操做都是用awk工具實現,針對test.txt
[root@centos001 ~]# awk -F ':' '{print $0}' test.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin

$0表示打印全部centos

  1. 查找全部包含 ‘bash’ 的行
[root@centos001 ~]# awk '/bash/' test.txt 
root:x:0:0:root:/root:/bin/bash
user1:x:1000:1000::/home/user1:/bin/bash
aming:x:1001:1007::/home/aming:/bin/bash
awei:x:1002:1002::/home/awei:/bin/bash
  1. 用 ‘:’ 做爲分隔符,查找第三段等於0的行
[root@centos001 ~]# awk -F ':' '$3==0'  test.txt 
root:x:0:0:root:/root:/bin/bash
  1. 用 ‘:’ 做爲分隔符,查找第一段爲 ‘root’ 的行,並把該段的 ‘root’ 換成 ‘toor’ (能夠連同sed一塊兒使用)
[root@centos001 ~]# awk -F ':' '$1==root' test.txt | sed 's/root/toor/' 
[root@centos001 ~]# awk -F ':' '$1=="root"' test.txt | sed 's/root/toor/' 
toor:x:0:0:root:/root:/bin/bash

第一段沒有正確輸出是由於沒有加雙引號,==是精確匹配,不加雙引號就會被認爲是數字bash

  1. 用 ‘:’ 做爲分隔符,打印最後一段
[root@centos001 ~]# awk -F ':' '{print $NF}' test.txt 
/bin/bash
/sbin/nologin

NF表示分隔符分隔後一共有多少段工具

  1. 打印行數大於20的全部行
[root@centos001 ~]# awk -F '#' 'NR>20' test.txt 
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
user1:x:1000:1000::/home/user1:/bin/bash
。。。。。。。。。。。。。。。。。。
[root@centos001 ~]# awk 'NR>20' test.txt 
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
user1:x:1000:1000::/home/user1:/bin/bash

第二個爲參考答案,因此 前面的#和-F是能夠不用加的。注意區分NF與NR的區別
NR爲行號code

  1. 用 ‘:’ 做爲分隔符,打印全部第三段小於第四段的行
[root@centos001 ~]# 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
  1. 用 ‘:’ 做爲分隔符,打印第一段以及最後一段,而且中間用 ‘@’ 鏈接 (例如,第一行應該是這樣的形式 'root@/bin/bash‘ )
[root@centos001 ~]# awk -F ':' '{print $1 "@" $NF}' test.txt 
root@/bin/bash
bin@/sbin/nologin

9.用 ‘:’ 做爲分隔符,把整個文檔的第四段相加,求和文檔

[root@centos001 ~]# awk -F ':' '{(tot=tot+$4)}; END {print tot}' test.txt 
11797

(tot=tot+$4)是一個循環,表示每一次循環都會把第三段的值相加;由於tot這個值不存在,因此這裏就是0+$3,在下一個就是$3加下一段的$3,以此類推test

相關文章
相關標籤/搜索