awk1.0 — awk基础
簡介
grep,sed,awk被稱為Linux文本處理的三劍客,各有特點
grep:適合文本的匹配和查找
sed:編輯匹配到的文本
awk:對文本進行格式化輸出
awk簡介
awk的基本語法是
awk [options] 'Pattern {Actions}' file1,file2...
Actions指的是工作,awk擅長文本輸出,最常用的動作是print和printf
場景一:簡單輸出文本
$ touch awk.cc
$ echo "ddd" > awk.cc
$ awk '{print}' awk.cc
ddd
場景二:格式的輸出某一列數據
上圖中,首先將df的結果通過管道傳給了awk,awk輸出了第五列的數據,$5表示第五個。
awk工作原理
awk會逐行獲取數據,然后對每一行進行處理,將一行中的數據按照“分隔符”分割成多個單次,并依次以1,1,2,3…等變量標記這些單詞。用戶可以指定分隔符,如果不指定的話,默認使用空格作為單詞之間的分隔符。awk內置變量,3…等變量標記這些單詞。用戶可以指定分隔符,如果不指定的話,默認使用空格作為單詞之間的分隔符。awk內置變量,0表示整行,NF表示一行中的最后一個變量(單詞)。還可以使用NF表示一行中的最后一個變量(單詞)。還可以使用(NF-1)表示倒數第一個變量。
其他輸出形式
記住一點,awk中的單詞都是以變量的形式存在
- 輸出多列,變量以逗號隔開
# df | awk '{print $1,$NF}'
- 輸出自定義變量
# df | awk '{print $1,$NF,"string"}'
需要注意的是,將$標識的變量和我們傳入的變量分清楚就好了
awk的模式
再次重申awk的語法
awk [options] 'Pattern {Actions}' file1,file2...
這里我們再來說awk的模式,awk有很多模式,先說兩個特殊的模式,BEGIN和END
BEGIN標識,在處理awk的操作之前,先要執行的操作,END標識,在執行完畢之后,再要執行的操作
BEGIN模式處理的一個優點就是,在格式化顯示文本之前,給每一列做一個標識,BEGIN就是執行awk之前先要進行的操作。
注意:多個操作強調內容一定要在單引號內(”),要有花括號分割({})
總結
以上是生活随笔為你收集整理的awk1.0 — awk基础的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 求一个带莹丫头字唯美qq网名。
- 下一篇: awk2.0 — awk分隔符