使用awk的next命令的方法
在awk系列文章中,我們來看一下next 命令 ,它告訴 awk 跳過你所提供的所有剩下的模式和表達(dá)式,直接處理下一個輸入行。next 命令幫助你阻止運(yùn)行命令執(zhí)行過程中多余的步驟。

要明白它是如何工作的, 讓我們來分析一下 food_list.txt 它看起來像這樣:
Food List Items NoItem_NamePrice Quantity 1 Mangoes $3.45 5 2 Apples$2.45 25 3 Pineapples $4.45 55 4 Tomatoes $3.45 25 5 Onions$1.45 15 6 Bananas $3.45 30 >
運(yùn)行下面的命令,它將在每個食物數(shù)量小于或者等于 20 的行后面標(biāo)一個星號:
# awk '$4 <= 20 { printf "%s/t%s/n", $0,"*" ; } $4 > 20 { print $0 ;} ' food_list.txt
No Item_Name PriceQuantity
1 Mangoes $3.45 5 *
2 Apples $2.4525
3 Pineapples $4.4555
4 Tomatoes$3.4525
5 Onions $1.4515*
6 Bananas $3.4530
上面的命令實(shí)際運(yùn)行如下:
1.它用$4 <= 20表達(dá)式檢查每個輸入行的第四列(數(shù)量(Quantity))是否小于或者等于 20,如果滿足條件,它將在末尾打一個星號 (*)。
2.它用$4 > 20表達(dá)式檢查每個輸入行的第四列是否大于20,如果滿足條件,顯示出來。
但是這里有一個問題, 當(dāng)?shù)谝粋€表達(dá)式用{ printf "%s/t%s/n", $0,"**" ; }命令進(jìn)行標(biāo)注的時候在同樣的步驟第二個表達(dá)式也進(jìn)行了判斷這樣就浪費(fèi)了時間。因此當(dāng)我們已經(jīng)用第一個表達(dá)式打印標(biāo)志行的時候就不再需要用第二個表達(dá)式$4 > 20再次打印。
要處理這個問題, 我們需要用到next 命令:
# awk '$4 <= 20 { printf "%s/t%s/n", $0,"*" ; next; } $4 > 20 { print $0 ;} ' food_list.txt

當(dāng)輸入行用$4 <= 20 { printf "%s/t%s/n", $0,"*" ; next ; }命令打印以后,next命令將跳過第二個$4 > 20 { print $0 ;}表達(dá)式,繼續(xù)判斷下一個輸入行,而不是浪費(fèi)時間繼續(xù)判斷一下是不是當(dāng)前輸入行還大于 20。
next命令在編寫高效的命令腳本時候是非常重要的,它可以提高腳本速度。
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信