這篇文章主要介紹如何使用awk按模式篩選文本或字符串,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完! 這篇文章主要介紹如何使用awk按模式篩選文本或字符串,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián),專注為中小企業(yè)提供官網(wǎng)建設(shè)、營銷型網(wǎng)站制作、響應(yīng)式網(wǎng)站設(shè)計、展示型成都網(wǎng)站制作、做網(wǎng)站等服務(wù),幫助中小企業(yè)通過網(wǎng)站體現(xiàn)價值、有效益。幫助企業(yè)快速建站、解決網(wǎng)站建設(shè)與網(wǎng)站營銷推廣問題。
讓我們看一看下面這個例子,比方說你有一個寫有你想要購買的食物的購物清單,其名稱為 food_prices.list,它所含有的食物名稱及相應(yīng)的價格如下所示:
$ cat food_prices.list No Item_Name Quantity Price 1 Mangoes 10 $2.45 2 Apples 20 $1.50 3 Bananas 5 $0.90 4 Pineapples 10 $3.46 5 Oranges 10 $0.78 6 Tomatoes 5 $0.55 7 Onions 5 $0.45
然后,你想使用一個 (*) 符號去標(biāo)記那些單價大于 $2 的食物,那么你可以通過運行下面的命令來達到此目的:
$ awk '/ */$[2-9]/.[0-9][0-9] */ { print $1, $2, $3, $4, "*" ; } / */$[0-1]/.[0-9][0-9] */ { print ; }' food_prices.list
打印出單價大于 $2 的項目
從上面的輸出你可以看到在含有芒果和菠蘿的那行末尾都已經(jīng)有了一個 (*) 標(biāo)記。假如你檢查它們的單價,你可以看到它們的單價的確超過了 $2 。
在這個例子中,我們已經(jīng)使用了兩個模式:
第一個模式: / */$[2-9]/.[0-9][0-9] */ 將會得到那些含有食物單價大于 $2 的行。
第二個模式: /*/$[0-1]/.[0-9][0-9] */ 將查找那些食物單價小于 $2 的那些行。
上面的命令具體做了什么呢?這個文件有四個字段,當(dāng)模式一匹配到含有食物單價大于 $2 的行時,它便會輸出所有的四個字段并在該行末尾加上一個 (*) 符號來作為標(biāo)記。
第二個模式只是簡單地輸出其他含有食物單價小于 $2 的行,按照它們出現(xiàn)在輸入文件 food_prices.list 中的樣子。
這樣你就可以使用模式來篩選出那些價格超過 $2 的食物項目,盡管上面的輸出還有些問題,帶有 (*) 符號的那些行并沒有像其他行那樣被格式化輸出,這使得輸出顯得不夠清晰。
我們在 awk 系列的第二部分中也看到了同樣的問題,但我們可以使用下面的兩種方式來解決:
1、可以像下面這樣使用 printf 命令,但這樣使用又長又無聊:
$ awk '/ */$[2-9]/.[0-9][0-9] */ { printf "%-10s %-10s %-10s %-10s/n", $1, $2, $3, $4 "*" ; } / */$[0-1]/.[0-9][0-9] */ { printf "%-10s %-10s %-10s %-10s/n", $1, $2, $3, $4; }' food_prices.list2、 使用 $0 字段。Awk 使用變量 0
來存儲整個輸入行。對于上面的問題,這種方式非常方便,并且它還簡單、快速:
$ awk '/ */$[2-9]/.[0-9][0-9] */ { print $0 "*" ; } / */$[0-1]/.[0-9][0-9] */ { print ; }' food_prices.list