語法格式:(1) Awk完整語法 awk BEGIN{commands} pattern{commands}END{commands} file BEGIN{commands}:處理數(shù)據(jù)前執(zhí)行的命令。END{commands}:處理完數(shù)據(jù)后執(zhí)行的命令。這兩個命令可以省略。
成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站建設(shè)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的巫溪網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
其中command是真正的awk命令,-F表示域的分隔符,是個可選項(xiàng)。
上圖中,我們使用-F選項(xiàng),指定了使用#號作為輸入分割符,于是,awk將每一行都通過#號為我們分割了。awk的內(nèi)置變量FS可以用于指定輸入分割符,但是在使用變量時,需要使用-v選項(xiàng),用于指定對應(yīng)的變量。
1 hello hello 2 data data 3 xyz abc 4 123 789 5 ftp 6 Apache 7 apache 然后,使用awk對f1文件內(nèi)容進(jìn)行處理,舉例如下。
簡單來說awk就是把文件逐行的讀入,以空格為默認(rèn)分隔符將每行切片,切開的部分再進(jìn)行各種分析處理。awk有三個不同的版本:awk、nawk和gawk,未作特別說明,一般指gawk,gawk是awk的GNU版本。
awk是一個強(qiáng)大的文本分析工具,相對于grep的查找,sed的編輯,awk在其對數(shù)據(jù)分析并生成報告時,顯得尤為強(qiáng)大。簡單來說awk就是把文件逐行的讀入,以空格為默認(rèn)分隔符將每行切片,切開的部分再進(jìn)行各種分析處理。
linux的awk一般都是gawk,/bin/awk - gawk awk ‘/abc/’ file.txt 顯示檔案中包含abc行。
break和continue常用于循環(huán)中;在awk中,數(shù)組的下標(biāo)可以是數(shù)字或字母。一般awk中的數(shù)組的作用是從記錄中收集信息,用于計算總和、統(tǒng)計單詞等。
除了使用sed命令,Linux系統(tǒng)中還有一個功能更加強(qiáng)大的文本數(shù)據(jù)處理工具,就是awk。它誕生于20世紀(jì)70年代末期,這也許是它影響了眾多Linux用戶的原因之一。
awk、grep、sed是linux文本操作的三大利器,grep適合單純的查找或文本匹配,sed適合編輯匹配到的文本,awk適合格式化文本,對文本進(jìn)行較復(fù)雜格式處理。
1、awk命令的基本格式[root@localhost]#awk[選項(xiàng)]腳本命令文件名。awk的強(qiáng)大之處在于腳本命令,它由2部分組成,分別為匹配規(guī)則和執(zhí)行命令。
2、Linux awk命令問題 head -n 3 /etc/passwd|awk -F : $1=root 這里$1=root,表示將第1列的值賦值為root,因此上述命令表示:將/etc/passwd中前3行按照‘:’分隔后第一列以root顯示,并列印其他列。
3、命令行方式 awk[-F field-separator]commandsinput-file(s)其中,commands是真正awk命令,[-F域分隔符]是可選的。input-file(s)是待處理的文件。在awk中,文件的每一行中,由域分隔符分開的每一項(xiàng)稱為一個域。
4、通過awk提取信息時,利用IP地址作為數(shù)組下標(biāo),每遇到一個重復(fù)值就將此數(shù)組元素遞增1,最終就獲得了這個IP地址出現(xiàn)的次數(shù)。 針對文本排序輸出可以采用sort命令,相關(guān)的常見選項(xiàng)為-r、-n、-k。
5、awk 的內(nèi)置變量。變量名稱 代表的含義 NF 每一行($0)擁有的字段總數(shù) NR 當(dāng)前 awk 所處理的是 “第幾行” 數(shù)據(jù) FS 當(dāng)前分隔符,默認(rèn)空格鍵 awk 的邏輯運(yùn)算符 特點(diǎn) AWK是一種優(yōu)良的文本處理工具。