awk的BEGIN和END

你可能對Unix比較熟悉,但你可能對Unix awk很陌生,這一點也不奇怪,的確,與其優秀的功能相比,awk還遠沒達到它應有的知名度。

流程控制語句是任何程序設計語言都不能缺少的部分。任何好的語言都有一些執行流程控制的語句。Unix awk提供的完備的流程控制語句類似於C語言,這給我們編程帶來了極大的方便。

BEGIN和END:

在Unix awk中兩個特別的表達式,BEGIN和END,這兩者都可用於pattern中(參考前面的awk語法),提供BEGIN和END的作用是給程序賦予初始狀態和在程序結束之後執行一些掃尾的工作。

任何在BEGIN之後列出的操作(在{}內)將在Unix awk開始掃描輸入之前執行,而END之後列出的操作將在掃描完全部的輸入之後執行。因此,通常使用BEGIN來顯示變量和預置(初始化)變量,使用END來輸出最終結果。

例:累計銷售文件xs中的銷售金額(假設銷售金額在記錄的第三字段):
$awk
'BEGIN { FS=":";print "統計銷售金額";total=0}
{print $3;total=total+$3;}
END {printf "銷售金額總計:%.2f",total}' sx
例2:容量字段累加
grep '19/03/12 22:' nohup.out| grep Successfully|awk '{print $9}' | awk -F= '{j=j+$2} END {i=j/1024/1024/1024;print j,i}'
846835162645 788.677

(注:>是shell提供的第二提示符,如要在shell程序Unix awk語句和Unix awk語言中換行,則需在行尾加反斜槓)

在這裏,BEGIN預置了內部變量FS(字段分隔符)和自定義變量total,同時在掃描之前顯示出輸出行頭。而END則在掃描完成後打印出總合計。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章