9.6 awk(上)

awk工具

  • head -n2 test.txt|awk -F ':' '{print $1}'
  • head -n2 test.txt|awk -F ':' '{print $0}'
  • awk -F ':' '{print $1"#"$2"#"$3"#"$4}'
  • awk '/oo/' test.txt
  • awk -F ':' '$1 ~/oo/' test.txt
  • awk -F ':' '/root/ {print $1,$3} /test/ {print $1,$3}' test.txt
  • awk -F ':' '$3=="0"' /etc/passwd
  • awk -F ':' '$3>="500"' /etc/passwd
  • awk -F ':' '$3>=500' /etc/passwd
  • awk -F ':' '$7!="/sbin/nologin"' /etc/passwd

awk功能前的準備工做

  • awk比sed更豐富的功能是,支持分段
[root@hf-01 ~]# mkdir awk
[root@hf-01 ~]# cd awk
[root@hf-01 awk]# cp /etc/passwd ./test.txt
[root@hf-01 awk]# ls
test.txt

awk命令 指定分割符

  • awk -F ':' '{print $1}' test.txt //打印出第一段內容
    • 分割符爲 :
  • head -n3 test.txt |awk -F ':' '{print $1}' //在文件前3行中,打印第一段內容
[root@hf-01 awk]# awk -F ':' '{print $1}' test.txt    //打印出第一段內容
root
bin
daemon
adm
lp
sync
shutdown
halt
等等等,只截取了一小部分

[root@hf-01 awk]# head -n3 test.txt |awk -F ':' '{print $1}'
root
bin
daemon
[root@hf-01 awk]#

awk命令以分隔符爲例,打印出第一段內容——>實際上並未去改變文件內容mysql

awk命令 指定打印某一段

  • awk -F ':' '{print $0}' test.txt //打印出全部的段
[root@hf-01 awk]# awk -F ':' '{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
等等等,只截取了一小部分
[root@hf-01 awk]#
  • 打印第一段用 $1 表示
  • 打印全部的段用 $0 表示

awk命令 指定打印多段內容,並指定以什麼爲分割

  • awk -F ':' '{print $1,$2,$4}' test.txt //打印指定的分段,第一段,第二段,第四段
    • 在打印多段內容的時候,只須要加 , 逗號 繼續添加便可
  • awk -F ':' '{print $1"@"$2"$4"}' test.txt //在前三行中打印指定的段,並指定用@ 進行分割
    • 括號裏面的分隔符,能夠爲 @ # 均可以使用
    • 括號裏面的指定的分隔符,須要使用 "" 雙引號標註出來
[root@hf-01 awk]# awk -F ':' '{print $1,$2,$4}' test.txt
root x 0
bin x 1
daemon x 2
adm x 4
lp x 7
sync x 0
shutdown x 0
等等等,只截取了一小部分

[root@hf-01 awk]# head -n3 test.txt |awk -F ':' '{print $1"@"$2"@"$4}'    //在前三行中,打印指定的段,並用 @ 分割
root@x@0
bin@x@1
daemon@x@2
[root@hf-01 awk]#

awk命令 打印全部文件內容

  • 若使用awk命令,忽略了使用 -F (沒有指定分割符),那麼它默認將會以 空格 或 空白字符 爲分割符去打印
  • awk '{print $0}' test.txt //打印出文件的全部內容——>至關於cat命令查看 [root@hf-01 awk]# 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 等等等,只截取了一小部分 [root@hf-01 awk]#

awk匹配功能(相似於grep命令的功能)

awk命令匹配打印包含字符的行

  • awk '/oo/' test.txt //打印匹配包含字符oo的行
[root@hf-01 awk]# awk '/oo/' test.txt    //打印匹配包含字符oo的行
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@hf-01 awk]#

awk命令匹配打印某一段中包含字符的行

  • awk -F ':' '$1 ~ /oo/' test.txt //打印第一段中包含oo的行
[root@hf-01 awk]# awk -F ':' '$1 ~ /oo/' test.txt
root:x:0:0:root:/root:/bin/bash
[root@hf-01 awk]#
  • awk -F ':' '$1 ~ /o+/' test.txt //匹配第一段中包含o字符的行
    • +號,表示一個或或多個+號前面的字符
[root@hf-01 awk]# awk -F ':' '$1 ~ /o+/' test.txt    //匹配第一段中包含o字符的行
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
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
[root@hf-01 awk]# 

[root@hf-01 awk]# awk -F ':' '$1 ~ /oo+/' test.txt
root:x:0:0:root:/root:/bin/bash
[root@hf-01 awk]#

這裏會發現,有特殊符號的時候,grep命令須要加 -E 脫義,sed命令須要加 -r 脫義,而awk命令中的特殊符號則不須要脫義就能夠實現操做sql

awk工具支持多個表達式一塊兒寫

  • awk -F ':' '/root/ {print $1,$3} /usr/ {print $3,$5}' test.txt //匹配包含root的行,打印第1段和第3段,而後在匹配包含usr的行並打印第3段和第4段
  • awk -F ':' '/root|usr/ {print $0}' test.txt //在文件全部段中,匹配包含root和usr的行
[root@hf-01 awk]# awk -F ':' '/root/ {print $1,$3} /usr/ {print $1,$3,$4}' test.txt    //匹配包含root的行,打印第1段和第3段,而後在匹配包含usr的行並打印第3段和第4段
root 0
operator 11
games 12 100
[root@hf-01 awk]# grep -E 'root|usr' test.txt
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
[root@hf-01 awk]# 

[root@hf-01 awk]# awk -F ':' '/root|usr/ {print $0}' test.txt    //在文件全部段中,匹配包含root和usr的行
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
[root@hf-01 awk]# awk -F ':' '/root|usr/ {print $1,$3,$4}' test.txt
root 0 0
operator 11 0
games 12 100
[root@hf-01 awk]#

awk工具支持多個表達式一塊兒寫bash

awk工具針對數學表達式

加單引號

  • awk -F ':' '$3==0' test.txt //匹配第3段等於0的,並打印全部段
    • 必須寫 兩個等於號,寫一個等於號就至關於 賦值
  • awk -F ':' '$3==0 {print $1}' test.txt //匹配第3段等於0的,並打印第1段
  • awk -F ':' '$3>=1000' test.txt //匹配第3段大於等於1000的,並打印全部段
[root@hf-01 awk]# awk -F ':' '$3==0' test.txt    //匹配第3段等於0的,並打印全部段
root:x:0:0:root:/root:/bin/bash
[root@hf-01 awk]# awk -F ':' '$3==0 {print $1}' test.txt    //匹配第3段等於0的,並打印第1段
root
[root@hf-01 awk]# awk -F ':' '$3>=1000 {print $0}' test.txt    //匹配第3段大於等於1000的,並打印全部段
mysql:x:1000:1000::/home/mysql:/bin/bash
[root@hf-01 awk]#

加雙引號

  • awk -F ':' '$3>="500"' test.txt //第三段大於等於500的
    • 加上雙引號後,會看到第三段的輸出的內容,都是以ascii碼的排序方式去計算的,它會認爲這是一個字符串,而不是一個數字去計算——>若需求是針對數字的,必定不能夠加 雙引號 !!!
[root@hf-01 awk]# awk -F ':' '$3>="1000" {print $0}' 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
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
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
mysql:x:1000:1000::/home/mysql:/bin/bash
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
[root@hf-01 awk]#
  • 如果字符串,則須要加上雙引號
  • awk -F ':' '$7!="/sbin/nologin" {print $0}' test.txt //匹配打印出第7段不等於/sbin/nologin的全部段
[root@hf-01 awk]# awk -F ':' '$7!="/sbin/nologin" {print $0}' test.txt     //匹配打印出第7段不等於/sbin/nologin的全部段
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
mysql:x:1000:1000::/home/mysql:/bin/bash
[root@hf-01 awk]#
相關文章
相關標籤/搜索