http://www.zsythink.net/archives/1336
awk [options] 'Pattern{Action}' file
BEGIN{} {} END{}
FS field separator
OFS output field separator
awk -F#
awk -v FS='#' OFS=':'
awk '{print $1, $2}' #有分隔符
awk '{print $1 $2}' # 沒有分隔符
RS 輸入記錄分隔符(輸入換行符) record separator
ORS 輸出記錄分隔符(輸出換行符) output record separator
NF number of field
NR number of record
FNR 各文件分別計(jì)數(shù)行號(hào)
FILENAME 當(dāng)前文件名
ARGC 命令行參數(shù)
ARGV 數(shù)組
awk -v myvar=1234 '{print myvar}'
awk 'BEGIN{myvar="1234", myvar2="aaa"}'
awk '{}' test1 test2 # ARGV=[awk, test1, test2], ARGC=3
print #輸出換行符
printf #默認(rèn)不輸出換行符
awk '{printf "%-10s\n", $1}'
awk 'NF==5{print $0}' #輸出列數(shù)為5的行
awk '/^abc/{print $0}' #輸出開頭為abc的行
awk -F ":" 'BEGIN{printf "%-10s\t%-10s\n", "username", "userID"} /^abc/{printf "%-10s\t%-10s\n", $1, $3}' /etc/passwd
awk --posix '/he{2,3}y/{print $0}' #匹配heey heeey
awk '/Lee/,/Kevin/{print $0}' #輸出第一次出現(xiàn)Lee與第一次出現(xiàn)Kevin之間的行
awk '{ if(NR==1){print $0}}else if(NR==2){print $0}else{}' #只打印第一行, 第二行
<
<=
==
!=
>=
>
~
!~
#for循環(huán)語法格式1
for(初始化; 布爾表達(dá)式; 更新) {
//代碼語句
}
#for循環(huán)語法格式2
for(變量 in 數(shù)組) {
//代碼語句
}
#while循環(huán)語法
while( 布爾表達(dá)式 ) {
//代碼語句
}
#do...while循環(huán)語法
do {
//代碼語句
}while(條件)
continue, break: also work
exit 結(jié)束
next 進(jìn)行下一行
awk 'BEGIN{huluwa[0]="大娃"; huluwa[1]="二娃"; delete huluwa[1]; delete huluwa;} {if(2 in huluwa){print "huluwa has key 2"}}'
#awk 下標(biāo)默認(rèn)從1開始
for(i in huluwa){print i, huluwa[i];}
cat test10
192.168.1.1
...
awk '{count[$1]++} END{for(i in count){print i, count[i];}}'
srand()
rand()
隨機(jī)數(shù)函數(shù)可用
print int(rand()*100)
#把$1(第一列)里的l全部換成L
awk '{gsub("l", "L", $1); print $0;}'
gsub全部替換
sub只替換第一個(gè)
length($1) #打印字符串長(zhǎng)度
index($0, "LEE") #查找正行中LEE的位置(從1開始計(jì)數(shù)), 0表示沒有
splite($0, huluwa, ":") #把整行數(shù)據(jù)按照:分割為數(shù)組, 數(shù)組叫huluwa
asort(t) #按照value對(duì)數(shù)組t從小到大排序, key重置為1, 2, 3...
asorti(t, newt) #取出t中key, 組成數(shù)組, 從小到大排序, key重置為1, 2, 3..., key的數(shù)組叫newt
支持三元運(yùn)算符
awk 'i=!i' # 打印奇數(shù)行, i為空值為false, !i為true, !i賦值給i, i為true, 因此第一行i為true, action默認(rèn)為打印全行, 下一行i為true, !i為false, false就不打印全行
awk '!(i=!i)' # 同理, 打印偶數(shù)行