欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

linux之awk命令的用法

 更新時間:2013年10月03日 10:41:32   作者:  
awk是一個非常棒的數字處理工具。相比于sed常常作用于一整行的處理,awk則比較傾向于將一行分為數個“字段”來處理。運行效率高,而且代碼簡單,對格式化的文本處理能力超強

先來一個例子:
文件a,統計文件a的第一列中是浮點數的行的浮點數的平均值。用awk來實現只需要一句話就可以搞定
$cat a
1.021 33
1#.ll   44
2.53 6
ss    7

awk 'BEGIN{total = 0;len = 0} {if($1~/^[0-9]+\.[0-9]*/){total += $1; len++}} END{print total/len}' a
(分析:$1~/^[0-9]+\.[0-9]*/表示$1與“/ /”里面的正則表達式進行匹配,若匹配,則total加上$1,且len自增,即數目加1.“^[0-9]+\.[0-9]*”是個正則表達式,“^[0-9]”表示以數字開頭,“\.”是轉義的意思,表示“.”為小數點的意思?!癧0-9]*”表示0個或多個數字)

awk的一般語法格式為:
awk [-參數 變量] 'BEGIN{初始化}條件類型1{動作1}條件類型2{動作2}。。。。END{后處理}'
其中:BEGIN和END中的語句分別在開始讀取文件(in_file)之前和讀取完文件之后發(fā)揮作用,可以理解為初始化和掃尾。

(1)參數說明:
-F re:允許awk更改其字段分隔符
-v var=$v 把v值賦值給var,如果有多個變量要賦值,那么就寫多個-v,每個變量賦值對應一個-v
e.g. 要打印文件a的第num行到num+num1行之間的行,
awk -v num=$num -v num1=$num1 'NR==num,NR==num+num1{print}' a
-f progfile:允許awk調用并執(zhí)行progfile程序文件,當然progfile必須是一個符合awk語法的程序文件。

(2)awk內置變量:
ARGC    命令行參數的個數
ARGV    命令行參數數組
ARGIND 當前被處理文件的ARGV標志符
e.g 有兩個文件a 和b
awk '{if(ARGIND==1){print "處理a文件"} if(ARGIND==2){print "處理b文件"}}' a b
文件處理的順序是先掃描完a文件,再掃描b文件

NR   已經讀出的記錄數
FNR    當前文件的記錄數
上面的例子也可以寫成這樣:
awk 'NR==FNR{print "處理文件a"} NR > FNR{print "處理文件b"}' a b
輸入文件a和b,由于先掃描a,所以掃描a的時候必然有NR==FNR,然后掃描b的時候,FNR從1開始計數,而NR則接著a的行數繼續(xù)計數,所以NR > FNR

e.g 要顯示文件的第10行至第15行
awk 'NR==10,NR==15{print}' a

FS   輸入字段分隔符(缺省為:space:),相當于-F選項
awk -F ':' '{print}' a    和   awk 'BEGIN{FS=":"}{print}' a 是一樣的

OFS輸出字段分隔符(缺省為:space:)
awk -F ':' 'BEGIN{OFS=";"}{print $1,$2,$3}' b
如果cat b為
1:2:3
4:5:6
那么把OFS設置成";"后就會輸出
1;2;3
4;5;6
(小注釋:awk把分割后的第1、2、3個字段用$1,$2,$3...表示,$0表示整個記錄(一般就是一整行))

NF:當前記錄中的字段個數
awk -F ':' '{print NF}' b的輸出為
3
3
表明b的每一行用分隔符":"分割后都3個字段
可以用NF來控制輸出符合要求的字段數的行,這樣可以處理掉一些異常的行
awk -F ':' '{if (NF == 3)print}' b

RS:輸入記錄分隔符,缺省為"\n"
缺省情況下,awk把一行看作一個記錄;如果設置了RS,那么awk按照RS來分割記錄
例如,如果文件c,cat c為
hello world; I want to go swimming tomorrow;hiahia
運行 awk 'BEGIN{ RS = ";" } {print}' c 的結果為
hello world
I want to go swimming tomorrow
hiahia
合理的使用RS和FS可以使得awk處理更多模式的文檔,例如可以一次處理多行,例如文檔d cat d的輸出為
1 2
3 4 5

6 7
8 9 10
11 12

hello
每個記錄使用空行分割,每個字段使用換行符分割,這樣的awk也很好寫
awk 'BEGIN{ FS = "\n"; RS = ""} {print NF}' d 輸出
2
3
1

ORS:輸出記錄分隔符,缺省為換行符,控制每個print語句后的輸出符號
awk 'BEGIN{ FS = "\n"; RS = ""; ORS = ";"} {print NF}' d 輸出
2;3;1

(3)awk讀取shell中的變量
可以使用-v選項實現功能
     $b=1
     $cat f
     apple

$awk -v var=$b '{print var, $var}' f
1 apple
至于有沒有辦法把awk中的變量傳給shell呢,這個問題我是這樣理解的。shell調用awk實際上是fork一個子進程出來,而子進程是無法向父進程傳遞變量的,除非用重定向(包括管道)
a=$(awk '{print $b, '$b'}' f)
$echo $a
apple 1

(4)輸出重定向

awk的輸出重定向類似于shell的重定向。重定向的目標文件名必須用雙引號引用起來。
$awk '$4 >=70 {print $1,$2 > "destfile" }' filename
$awk '$4 >=70 {print $1,$2 >> "destfile" }' filename

(5)awk中調用shell命令:

1)使用管道
awk中的管道概念和shell的管道類似,都是使用"|"符號。如果在awk程序中打開了管道,必須先關閉該管道才能打開另一個管道。也就是說一次只能打開一個管道。shell命令必須被雙引號引用起來。“如果打算再次在awk程序中使用某個文件或管道進行讀寫,則可能要先關閉程序,因為其中的管道會保持打開狀態(tài)直至腳本運行結束。注意,管道一旦被打開,就會保持打開狀態(tài)直至awk退出。因此END塊中的語句也會收到管道的影響。(可以在END的第一行關閉管道)”
awk中使用管道有兩種語法,分別是:
awk output | shell input
shell output | awk input

對于awk output | shell input來說,shell接收awk的輸出,并進行處理。需要注意的是,awk的output是先緩存在pipe中,等輸出完畢后再調用shell命令 處理,shell命令只處理一次,而且處理的時機是“awk程序結束時,或者管道關閉時(需要顯式的關閉管道)”
$awk '/west/{count++} {printf "%s %s\t\t%-15s\n", $3,$4,$1 | "sort +1"} END{close "sort +1"; printf "The number of sales pers in the western"; printf "region is " count "." }' datafile (解釋:/west/{count++}表示與“wes”t進行匹配,若匹配,則count自增)
printf函數用于將輸出格式化并發(fā)送給管道。所有輸出集齊后,被一同發(fā)送給sort命令。必須用與打開時完全相同的命令來關閉管道(sort +1),否則END塊中的語句將與前面的輸出一起被排序。此處的sort命令只執(zhí)行一次。

在shell output | awk input中awk的input只能是getline函數。shell執(zhí)行的結果緩存于pipe中,再傳送給awk處理,如果有多行數據,awk的getline命令可能調用多次。
$awk 'BEGIN{ while(("ls" | getline d) > 0) print d}' f

相關文章

  • C++使用HTTP庫和框架輕松發(fā)送HTTP請求

    C++使用HTTP庫和框架輕松發(fā)送HTTP請求

    使用C++編程發(fā)送HTTP請求通常需要使用第三方的HTTP庫或框架,本文主要介紹了C++使用HTTP庫和框架輕松發(fā)送HTTP請求,感興趣的可以了解一下
    2023-12-12
  • C++對string進行大小寫轉換操作方法

    C++對string進行大小寫轉換操作方法

    這篇文章主要介紹了C++對string進行大小寫轉換操作方法,本文通過兩種方法結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • C++之編寫高效Makefile文件最佳方法

    C++之編寫高效Makefile文件最佳方法

    在軟件開發(fā)過程中,Makefile是一個非常重要的工具,它可以幫助我們自動化構建、編譯、測試和部署,然而,編寫高效的Makefile文件并不是一件容易的事情。在本文中,我們將討論如何編寫高效的Makefile文件,以提高開發(fā)效率和產品質量,需要的朋友可以參考下
    2023-05-05
  • c++中為什么不提倡使用vector示例詳解

    c++中為什么不提倡使用vector示例詳解

    這篇文章主要給大家介紹了關于c++中為什么不提倡使用vector的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用c++具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • JsonCpp中double的問題解決

    JsonCpp中double的問題解決

    本文主要介紹了JsonCpp中double的問題解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++基于Floyd算法實現校園導航系統

    C++基于Floyd算法實現校園導航系統

    這篇文章主要為大家詳細介紹了C++基于Floyd算法實現校園導航系統,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++回溯算法中的全排列問題分析探討

    C++回溯算法中的全排列問題分析探討

    遞歸中遇到一個問題全排列的問題,我看見回溯特別神奇,特此記錄一下。對比一下深度優(yōu)先搜索與廣度優(yōu)先搜索,個人感覺這里的回溯像是一種遞歸樹中的深度優(yōu)先搜索的算法,他不斷構造往下延伸的深度,使其達到完全編列
    2023-03-03
  • C語言深入講解指針與結構體的使用

    C語言深入講解指針與結構體的使用

    指針提供了對地址操作的一種方法,因此,使用指針可使得C語言能夠更高效地實現對計算機底層硬件的操作。另外,通過指針可以更便捷地操作數組。C數組允許定義可存儲相同類型數據項的變量,結構是C編程中另一種用戶自定義的可用的數據類型,它允許您存儲不同類型的數據項
    2022-05-05
  • 分析C語言一個簡單程序

    分析C語言一個簡單程序

    本文主要介紹C語言簡單的程序,這里給大家詳細介紹C語言代碼,對函數概念、頭文件、自定義函數等基礎信息的講解,希望能幫助剛剛學習的同學
    2016-07-07
  • 基于VC編寫COM連接點事件的分析介紹

    基于VC編寫COM連接點事件的分析介紹

    本篇文章是對VC編寫COM連接點事件進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05

最新評論