主頁(yè) > 知識(shí)庫(kù) > awk正則表達(dá)式和內(nèi)置函數(shù)的使用方法實(shí)例詳解

awk正則表達(dá)式和內(nèi)置函數(shù)的使用方法實(shí)例詳解

熱門標(biāo)簽:旅游地圖標(biāo)注大全 地圖標(biāo)注超出范圍怎么辦 百度地圖標(biāo)注圖標(biāo)更換 佛山高德地圖標(biāo)注中心 excel地址地圖標(biāo)注 杭州機(jī)器人外呼系統(tǒng) 陜西電銷卡外呼系統(tǒng)怎么安裝 百度地圖的地圖標(biāo)注 東莞電銷機(jī)器人價(jià)格一覽表

awk正則表達(dá)式及內(nèi)置函數(shù)實(shí)例詳解:

1、模糊匹配:

復(fù)制代碼 代碼如下:

awk ‘{if($3~/97/) print $0}' data.f:如果第三項(xiàng)中含有”97”則打印該行
awk ‘{if($4!~/ufcx/) print $0}' data.f:如果第三項(xiàng)中不含ufcx有則打印

2、精確匹配:

復(fù)制代碼 代碼如下:

awk ‘{if($5==66) print $0}' data.f:如果第五項(xiàng)是66則打印
awk ‘{if($5!=66)print $0}' data.f : 如果第五項(xiàng)不是66則打印
awk ‘{if($1>$5) print $0}' data.f:如果第一項(xiàng)大于第五項(xiàng)則打印

3、大小寫(xiě)匹配:

復(fù)制代碼 代碼如下:

awk ‘{if(/[Ss]ept/) print $0}' data.f:符合,則打印一行。
awk ‘/[Ss]ept/ {print $2}' data.f:符合,則打印第二字段

4、任意匹配:

復(fù)制代碼 代碼如下:

awk ‘{if($2 ~/^.e/) print $0}' data.f:第二字段中,第二個(gè)字符為e,輸出
awk ‘{if($4 ~/(lps|fcx)/) print $0}' data.f:第四個(gè)字段含有l(wèi)ps或fcx則輸出

5、,||:

復(fù)制代碼 代碼如下:

awk ‘{if($3 ~/1993/ $2==”sept”) print $0}' data.f:兩邊都真則輸出
awk ‘{if($3 ~/a9/ || $2==”sept”) print $0}' data.f:一邊為真則輸出

6、變量定義:

awk ‘{date=$2;price=$5; if(date ~/[Ss]ept/) print “price is ” price}' data.f:變量定義,滿足date是sept或者Sept的將price輸出。

7、修改數(shù)值(源文件數(shù)值不變)

復(fù)制代碼 代碼如下:

awk ‘{BASELINE=42; if($1>BASELINE) $5=$5+100; print $0}' data.f:三行程序,以“;”分割

如果修改的是文本域,就要添加“”””。例如:awk ‘{if($2==”may”) $2=”tt”; print $0}' data.f

上邊都是顯示所有數(shù)據(jù),awk ‘{if($2==”may”) {$2=”tt”; print $0}}' data.f這個(gè)只顯示修改數(shù)據(jù),仔細(xì)看看,其實(shí)語(yǔ)法和c一樣,只是最外邊添加了一個(gè){}符號(hào)。

8、創(chuàng)建新域:(源文件數(shù)值不變)

復(fù)制代碼 代碼如下:

awk ‘{if($5>$1){$8=$5-$1;print $1,$8}}' data.f:

或者awk ‘{if($5>$1){diff=$5-$1;print $1,diff}}' data.f

9、數(shù)據(jù)統(tǒng)計(jì):

awk ‘{(total+=$5)}END{print total}' data.f:“{(total+=$5)}”和“{print total}”代表兩個(gè)不同的代碼段,如果沒(méi)有END每次的累積結(jié)果都會(huì)輸出,END可以理解為代碼段落的標(biāo)志,這樣只輸出最終結(jié)果即{print total}只執(zhí)行一次。

10、統(tǒng)計(jì)文件大?。?/strong>

復(fù)制代碼 代碼如下:

ls –l | awk ‘{if(/^[^d]/) total=+$5}END{print “total KB:” total}':/^[^d]/行首匹配可以不寫(xiě)域值$1

11、Awk內(nèi)置變量:

ARGC 命令行參數(shù)個(gè)數(shù)

ARGV 命令行參數(shù)排列

ENVIRON 支持隊(duì)列中系統(tǒng)環(huán)境變量的使用

FILENAME awk瀏覽的文件名

FNR 瀏覽文件的記錄數(shù)

FS 設(shè)置輸入域分隔符,等價(jià)于命令行- F選項(xiàng)

NF 瀏覽記錄的域個(gè)數(shù)

NR 已讀的記錄數(shù)

OFS 輸出域分隔符

ORS 輸出記錄分隔符

RS 控制記錄分隔符

12、awk內(nèi)置字符串處理函數(shù)

gsub ( r, s )在整個(gè)$0中用s替代r

gsub ( r, s , t )在整個(gè)t中用s替代r

index ( s , t )返回s中字符串t的第一位置

length ( s )返回s長(zhǎng)度

match ( s , r )測(cè)試s是否包含匹配r的字符串,返回位置

split ( s , a , fs )在fs上將s分成序列a

sprint ( f m t , exp )返回經(jīng)f m t格式化后的exp

sub ( r, s ,$0) $0中s替換第一次r出現(xiàn)的位置

substr ( s , p )返回字符串s中從p開(kāi)始的后綴部分

substr ( s , p , n )返回字符串s中從p開(kāi)始長(zhǎng)度為n的后綴部分

13、awk ‘gsub(/6\./,78) {print $0}' data.f:將所有“6.”換成78,并輸出

復(fù)制代碼 代碼如下:

awk ‘{if($2==”Sept”) {sub(/3/,”9″,$0); print $0}}' data.f:只替換第一個(gè)出現(xiàn)的

awk ‘BEGIN{print index(“hello”,”lo”)}':輸出的值為4

awk ‘{if($3==”3BC1997″) print length($3) ” ” $3}' data.f

awk ‘BEGIN{print match(“ABCD”,”B”)}':輸出2

awk ‘BEGIN{print match(“ABCD”,/B/)}':“//”和“”””效果一樣

awk ‘BEGIN {print split(“123#234#654″, myarray, “#”)}':返回?cái)?shù)組元素個(gè)數(shù),123#234#654是字符串,以“#”為分隔符,將字符串放入數(shù)組。

awk ‘{if($1==34) print substr($3,2,7)}' data.f

awk ‘BEGIN{print substr(“helloleeboy”,2,7)}':輸出ellole

awk ‘BEGIN{print substr(“helloleeboy”,2,7)}' data.f:輸出n遍ellole,n為data.f的行數(shù)

14、awk ‘BEGIN{print”May\tDay\n\nMay \104\141\171″}':\104\141\171表示Day。\t:tab鍵,\n:換行,\ddd:八進(jìn)制

15、echo “65” | awk ‘{printf “%c\n”,$0}':printf函數(shù),和c差不多,輸出為A。(ASCII碼)

復(fù)制代碼 代碼如下:

echo “65” | awk ‘{printf “%d\n”,$0}':輸出65數(shù)字。

awk ‘{printf “%-15s %s\n”,$2,$3}' data.f:“%-15s”左對(duì)齊15個(gè)字符長(zhǎng)度

awk ‘{if(age$1) print $0}' age=80 data.f和 awk ‘{age=49;if(age$1) print $0}' data.f結(jié)果一樣,前者將值傳入awk,后者在awk中定義了一個(gè)變量。

您可能感興趣的文章:
  • 詳解Linx awk 入門教程
  • Linux中的awk數(shù)組的基本使用方法
  • 淺談linux中sed命令和awk命令的使用
  • LINUX中詳解AWK內(nèi)建變量FS,NF,NR,RT,RS,ORS,OFS
  • Linux中 sed 和 awk的用法詳解
  • 一天一個(gè)shell命令 linux文本內(nèi)容操作系列-awk命令詳解
  • linux正則表達(dá)式awk詳解
  • Shell正則表達(dá)式之grep、sed、awk實(shí)操筆記
  • 馬爾可夫鏈算法(markov算法)的awk、C++、C語(yǔ)言實(shí)現(xiàn)代碼
  • awk命令、awk編程語(yǔ)言詳細(xì)介紹和實(shí)例
  • Linux awk將文件某列按照逗號(hào)分隔的例子

標(biāo)簽:隨州 延邊 雅安 朝陽(yáng) 青島 通遼 南充 西藏

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《awk正則表達(dá)式和內(nèi)置函數(shù)的使用方法實(shí)例詳解》,本文關(guān)鍵詞  awk,正則,表達(dá)式,和,內(nèi)置,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《awk正則表達(dá)式和內(nèi)置函數(shù)的使用方法實(shí)例詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于awk正則表達(dá)式和內(nèi)置函數(shù)的使用方法實(shí)例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章