日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Awk用模式篩選文本或字符串

在篩選文本時(shí),有時(shí)你可能想根據(jù)某個(gè)給定的條件或使用一個(gè)可被匹配的特定模式,去標(biāo)記某個(gè)文件或數(shù)行字符串中的某幾行。使用 awk 來(lái)完成這個(gè)任務(wù)是非常容易的,這也正是 awk 中可能對(duì)你有所幫助的幾個(gè)功能之一。

創(chuàng)新互聯(lián)建站成立于2013年,我們提供高端成都網(wǎng)站建設(shè)公司、重慶網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、網(wǎng)站定制、網(wǎng)絡(luò)營(yíng)銷推廣、小程序制作、微信公眾號(hào)開發(fā)、seo優(yōu)化服務(wù),提供專業(yè)營(yíng)銷思路、內(nèi)容策劃、視覺設(shè)計(jì)、程序開發(fā)來(lái)完成項(xiàng)目落地,為成都木包裝箱企業(yè)提供源源不斷的流量和訂單咨詢。

讓我們看一看下面這個(gè)例子,比方說(shuō)你有一個(gè)寫有你想要購(gòu)買的食物的購(gòu)物清單,其名稱為 food_prices.list,它所含有的食物名稱及相應(yīng)的價(jià)格如下所示:

$ 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

然后,你想使用一個(gè) (*) 符號(hào)去標(biāo)記那些單價(jià)大于 $2 的食物,那么你可以通過運(yùn)行下面的命令來(lái)達(dá)到此目的:

$ awk '/ */$[2-9]/.[0-9][0-9] */ { print $1, $2, $3, $4, "*" ; } / */$[0-1]/.[0-9][0-9] */ { print ; }' food_prices.list

打印出單價(jià)大于 $2 的項(xiàng)目

從上面的輸出你可以看到在含有芒果和菠蘿的那行末尾都已經(jīng)有了一個(gè) (*) 標(biāo)記。假如你檢查它們的單價(jià),你可以看到它們的單價(jià)的確超過了 $2 。

在這個(gè)例子中,我們已經(jīng)使用了兩個(gè)模式: 第一個(gè)模式: / */$[2-9]/.0-9 */ 將會(huì)得到那些含有食物單價(jià)大于 的行。第二個(gè)模式[0-1]/.0-9 */ 將查找那些食物單價(jià)小于 $2 的那些行。

上面的命令具體做了什么呢?這個(gè)文件有四個(gè)字段,當(dāng)模式一匹配到含有食物單價(jià)大于 $2 的行時(shí),它便會(huì)輸出所有的四個(gè)字段并在該行末尾加上一個(gè) (*) 符號(hào)來(lái)作為標(biāo)記。

第二個(gè)模式只是簡(jiǎn)單地輸出其他含有食物單價(jià)小于 $2 的行,按照它們出現(xiàn)在輸入文件 food_prices.list 中的樣子。

這樣你就可以使用模式來(lái)篩選出那些價(jià)格超過 $2 的食物項(xiàng)目,盡管上面的輸出還有些問題,帶有 (*) 符號(hào)的那些行并沒有像其他行那樣被格式化輸出,這使得輸出顯得不夠清晰。

我們?cè)?awk 系列的第二部分中也看到了同樣的問題,但我們可以使用下面的兩種方式來(lái)解決:

1、可以像下面這樣使用 printf 命令,但這樣使用又長(zhǎng)又無(wú)聊:

$ 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.list

使用 Awk 和 Printf 來(lái)篩選和輸出項(xiàng)目

2、 使用 $0 字段。Awk 使用變量 0 來(lái)存儲(chǔ)整個(gè)輸入行。對(duì)于上面的問題,這種方式非常方便,并且它還簡(jiǎn)單、快速:

$ awk '/ */$[2-9]/.[0-9][0-9] */ { print $0 "*" ; } / */$[0-1]/.[0-9][0-9] */ { print ; }' food_prices.list

使用 Awk 和變量來(lái)篩選和輸出項(xiàng)目


本文名稱:Awk用模式篩選文本或字符串
分享鏈接:http://m.5511xx.com/article/cdipipd.html