- 常用操作
[stark_summer@localhost ~]$ awk '/^root/{print $0}' /etc/passwd
root:x:::root:/root:/bin/bash
/^root/ 為選擇表達式,$0代表是逐行
- 設定字段分隔符号(FS使用方法)
[stark_summer@localhost ~]$ awk 'BEGIN{FS=":"}/^root/{print $1,$NF}' /etc/passwd
root /bin/bash
FS為字段分隔符,可以自己設定,預設是空格,因為passwd裡面是”:”分隔,是以需要修改預設分隔符。NF是字段總數,$0代表目前行記錄,$1-$n是目前行,各個字段對應值。
- 記錄條數(NR,FNR使用方法)
[stark_summer@localhost ~]$ awk 'BEGIN{FS=":"}{print NR,$1,$NF}' /etc/passwd
root /bin/bash
bin /sbin/nologin
daemon /sbin/nologin
adm /sbin/nologin
lp /sbin/nologin
sync /bin/sync
shutdown /sbin/shutdown
NR得到目前記錄所在行
- 設定輸出字段分隔符(OFS使用方法)
[stark_summer@localhost ~]$ awk 'BEGIN{FS=":";OFS="^^"}/^root/{print FNR,$1,$NF}' /etc/passwd
^^root^^/bin/bash
OFS設定預設字段分隔符
- 設定輸出行記錄分隔符(ORS使用方法)
[[email protected] ~]$ awk 'BEGIN{FS=":";ORS="^^"}{print FNR,$1,$NF}' /etc/passwd
root /bin/bash^^2 bin /sbin/nologin^^3 daemon /sbin/nologin^^4 adm /sbin/nologin^^5 lp /sbin/nologin
從上面看,ORS預設是換行符,這裡修改為:”^^”,所有行之間用”^^”分隔了。
- 輸入參數擷取(ARGC ,ARGV使用)
[[email protected] ~]$ awk 'BEGIN{FS=":";print "ARGC="ARGC;for(k in ARGV) {print k"="ARGV[k]; }}' /etc/passwd
ARGC=
=awk
=/etc/passwd
ARGC得到所有輸入參數個數,ARGV獲得輸入參數内容,是一個數組。
- 獲得傳入的檔案名(FILENAME使用)
[stark_summer@localhost ~]$ awk 'BEGIN{FS=":";print FILENAME}{print FILENAME}' /etc/passwd
/etc/passwd
FILENAME,$0-$N,NF 不能使用在BEGIN中,BEGIN中不能獲得任何與檔案記錄操作的變量。
- 獲得linux環境變量(ENVIRON使用)
[[email protected] ~]$ awk 'BEGIN{print ENVIRON["PATH"];}' /etc/passwd
/usr/lib/qt-/bin:/usr/kerberos/bin:/usr/lib/ccache:/usr/lib/icecc/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/java/jdk1_17/bin:/usr/java/jdk1_17/jre/bin:/usr/local/mysql/bin:/home/web97/bin
ENVIRON是子典型數組,可以通過對應鍵值獲得它的值。
- 輸出資料格式設定:(OFMT使用)
[stark_summer@localhost ~]$ awk 'BEGIN{OFMT="%.3f";print 2/3,123.11111111;}' /etc/passwd
.
OFMT預設輸出格式是:%.g 保留六位小數,這裡修改OFMT會修改預設資料輸出格式。
- 按寬度指定分隔符(FIELDWIDTHS使用)
[[email protected] ~]$ echo | awk 'BEGIN{FIELDWIDTHS=" "}{print $1"-"$2"-"$3,$4":"$5":"$6}'
-- ::
FIELDWIDTHS其格式為空格分隔的一串數字,用以對記錄進行域的分隔,FIELDWIDTHS=" "就表示$1寬度是,$2是,$3是 .... 。這個時候會忽略:FS分隔符。
- RSTART RLENGTH使用
[[email protected] ~]$ awk 'BEGIN{start=match("this is a test",/[a-z]+$/); print start, RSTART, RLENGTH }'
11 11 4
[[email protected] ~]$ awk 'BEGIN{start=match("this is a test",/^[a-z]+$/); print start, RSTART, RLENGTH }'
0 0 –1
RSTART 被比對正規表達式首位置,RLENGTH 比對字元長度,沒有找到為-1.