7.5 9.6-9.7
-F 指定分隔符,打印每一行第一段
[root@hyc-01-01 awk]# awk -F ':' '{print $1}' test.txt
打印每一行所有的段
[root@hyc-01-01 awk]# awk -F ':' '{print $0}' test.txt
打印文件所有內容
[root@hyc-01-01 awk]# awk '{print $0}' test.txt
若不使用-F指定分隔符,則將把空格或空白字符當做分隔符打印
[root@hyc-01-01 awk]# cat 11.txt
aa bb cc
dd ee ff
gg vv hh
[root@hyc-01-01 awk]# awk '{print $1}' 11.txt
aa
dd
gg 此時以空格作為分隔符
打印多段內容
[root@hyc-01-01 awk]# awk '{print $1,$3}' 11.txt
aa cc
dd ff
gg hh
在顯示的結果中加入符號(符號需要引起來)
[root@hyc-01-01 awk]# awk '{print $1"#"$3}' 11.txt
aa#cc
dd#ff
gg#hh
匹配包含oo的行
[root@hyc-01-01 awk]# 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
匹配第一段包含oo的行
[root@hyc-01-01 awk]# awk -F ':' '$1 ~ /oo/' test.txt
root:x:0:0:root:/root:/bin/bash
匹配第一段至少有一個o的行
[root@hyc-01-01 awk]# awk -F ':' '$1 ~ /o+/' test.txt
root:x:0:0:root:/root:/bin/bash
daemon:x:2:2:daemon:/sbin:/sbin/nologin
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
operator:x:11:0:operator:/root:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
polkitd:x:999:997:User for polkitd:/:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
匹配第一段至少有2個o的行
[root@hyc-01-01 awk]# awk -F ':' '$1 ~ /oo+/' test.txt
root:x:0:0:root:/root:/bin/bash
匹配root的行打印第1和第3段,匹配hyc的行打印第6和第7段
[root@hyc-01-01 awk]# awk -F ':' '/root/ {print $1,$3} /hyc/ {print $6"#"$7}' test.txt
root 0
operator 11
/home/hyc/#/bin/bash
$0表示一行的所有內容,即每一段
匹配第3段等於0的行並打印該行的第1段
[root@hyc-01-01 awk]# awk -F ':' '$3==0 {print $1}' test.txt
Root
匹配第3段等於0的行並打印該行
[root@hyc-01-01 awk]# awk -F ':' '$3==0' test.txt
root:x:0:0:root:/root:/bin/bash
= 表示賦值,為某個變量賦值時使用
== 表示等號
匹配第3段大於等於1000的行並打印該行
[root@hyc-01-01 awk]# awk -F ':' '$3>=1000' test.txt
hyc1:x:1000:1000:/home/hyc1/:/bin/bash
在和數字比較時,若把比較的數字用雙引號引起來後,那麽awk不會認為是數字,而認為是字符,不加雙引號則認為是數字
[root@hyc-01-01 awk]# awk -F ':' '$3>="1000"' test.txt
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
…
匹配第7段不是/sbin/nologin的行並打印匹配行
[root@hyc-01-01 awk]# awk -F ':' '$7!="/sbin/nologin" {print $0}' test.txt
root:x:0:0:root:/root:/bin/bash
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
hyc:x:999:999::/home/hyc/:/bin/bash
hyc1:x:1000:1000:/home/hyc1/:/bin/bash
!= 代表不等於;
匹配字符串時需要加雙引號;
9.7 awk(下)
7.5 9.6-9.7