今天小編給大家分享一下linux awk命令如何使用的相關知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
站在用戶的角度思考問題,與客戶深入溝通,找到昌吉網(wǎng)站設計與昌吉網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設計與互聯(lián)網(wǎng)技術結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設計、成都網(wǎng)站建設、外貿(mào)網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)絡空間、企業(yè)郵箱。業(yè)務覆蓋昌吉地區(qū)。
在linux中,awk命令是文本數(shù)據(jù)處理工具,適合格式化文本文件,對文本文件進行更復雜的加工處理、分析,語法“awk [option] 'pattern[action]' file ...”。awk具備強大的文本格式化能力,比如對一堆看起來沒有什么規(guī)律的日志文件,文本文件等,通過awk命令之后,格式化輸出為專業(yè)的可以做為應用級數(shù)據(jù)分析的樣式。
Linux 系統(tǒng)中有一個功能更加強大的文本數(shù)據(jù)處理工具,就是 awk。它誕生于 20 世紀 70 年代末期,這也許是它影響了眾多 Linux 用戶的原因之一。
曾有人推測 awk 命令的名字來源于 awkward 這個單詞。其實不然,此命令的設計者有 3 位,他們的姓分別是 Aho、Weingberger 和 Kernighan,awk 就取自這 3 為大師姓的首字母。
awk具備強大的文本格式化能力,比如對一堆看起來沒有什么規(guī)律的日志文件,文本文件等,通過awk命令之后,格式化輸出為專業(yè)的可以做為應用級數(shù)據(jù)分析的樣式;
awk像是一門編程語言,支持條件判斷,數(shù)組,循環(huán)等諸多的功能。
grep,擅長單純的查找或匹配文本內(nèi)容;
sed,擅長文本編輯,處理匹配到的文本內(nèi)容;
awk,適合格式化文本文件,對文本文件進行更復雜的加工處理、分析;
1、awk語法
awk [option] 'pattern[action]' file ...
awk 參數(shù) 條件動作 文件
action 是指動作,awk擅長文本格式化,且能輸出格式化后的結(jié)果,因此最常用的動作就是 print 和 printf
2、awk處理文本內(nèi)容模式
awk默認以空格為分隔符,且多個空格也識別為一個空格,作為分隔符;
awk按行處理文件,一行處理完畢之后,再處理下一行;
awk可以根據(jù)用戶指定的分隔符去工作,沒有指定,則默認為空格;
內(nèi)置變量 | 說明 |
---|---|
$n | 指定分隔符后,當前的第n個列所在的字段 |
$0 | 完整的一行記錄 |
FS | 字段分隔符,默認是空格 |
NF(Number of fields) | 字段分隔后,當前一共多少個字段 |
NR(Number of records) | 當前記錄數(shù),行數(shù) |
更多的內(nèi)置變量,可通過 man awk命令進行查看
簡單案例展示
提前準備一個文本,內(nèi)容如下
1、輸出第二列內(nèi)容
awk '{print $2}' alx.txt
2、輸出多列內(nèi)容
直接在第一步后面的基礎上追加,中間用 “,” 分割
awk '{print $2,$3}' alx.txt
3、查看第三行內(nèi)容
考察對NR的使用,NR表示第N行記錄的模式匹配
awk 'NR==3{print $0}' alx.txt
輸出多行
awk 'NR==5,NR==6{print $0}' alx.txt
4、輸出從第3到第五行,并顯示行號
awk 'NR==3,NR==5 {print NR,$0}' alx.txt
5、自定義輸出內(nèi)容
某些情況下,需要給每一列添加類似于excel的表頭信息,就可以考慮使用awk的自定義輸出;
awk '{print "第一列: "$1,"第二列: "$2}' alx.txt
需要注意的是大括號外面的使用 ’ 單引號,括號里面的使用雙引號
參數(shù) | 說明 |
---|---|
-F | 指定分隔字段符 |
-v | 定義或修改一個awk內(nèi)部變量 |
-f | 從腳本文件中讀取awk命令 |
上文談到,awk默認的字段分隔符為空格,但是像下面這樣的文本,以 # 為分隔符,就需要用到自定義分隔符;
1、顯示第一列和第二列內(nèi)容
awk -F "#" '{print $1,$2}' zcy2.txt
2、顯示文件第一列,倒是第一列,和倒數(shù)第二列的內(nèi)容
awk '{print $1,$(NF-1),$(NF-2)}' alx.txt
3、取出本機的IP地址
使用awk的方式獲取的話,如果以空格為分隔符,我們發(fā)現(xiàn)目標字段在第二行的第二列,使用下面的命令即可,看起來,比起sed和grep命令似乎更簡單;
ifconfig eth0 | awk 'NR==2{print $2}'
4、取出密碼文件中的第一列和最后一列
考察對自定義輸入分隔符的使用,可以看到,下面的文本文件中,可以考慮使用 : 進行分割;
awk -F ':' '{print $1,$NF}' pwd2.txt
通過上文的學習,我們知道awk命令執(zhí)行后,默認采用空格分割字段,而這個空格就是默認的輸出分割符,
單在某些情況下,為了將數(shù)據(jù)展示的效果更加醒目一些,就可以使用OFS的自定義輸出分隔符;
仍然以上面的密碼文本為例,輸出第一列和最后一列的字段;
awk -F ':' -v OFS=' *** ' '{print $1,$NF}' pwd2.txt
該表默認輸出分隔符,直接在awk后面使用: -v OFS=‘自定義輸出分隔符’
awk參數(shù)
參數(shù) | 說明 |
---|---|
-F | 指定分隔字段符 |
-v | 定義或修改一個awk內(nèi)部變量 |
-f | 從腳本文件中讀取awk命令 |
對于awk來講,變量分為:內(nèi)置變量和自定義變量
awk內(nèi)置變量
參數(shù) | 說明 |
---|---|
FS | 輸入字段分隔符,默認為空白字符 |
OFS | 輸出字段分隔符,默認為空白字符 |
RS | 輸入記錄分隔符,指定輸入時的換行符 |
ORS | 輸出記錄分隔符,輸出時用指定符號替換換行符 |
NF | 當前行的字段個數(shù),字段數(shù)量 |
NR | 行號,當前處理文本行的行號 |
FNR | 各文件分別計數(shù)的行號 |
FILENAME | 當前文件名 |
ARGC | 命令行參數(shù)個數(shù) |
ARGV | 數(shù)組,保存的是命令行所給定的各個參數(shù) |
比較常用的內(nèi)置變量包括: NR,NF,F(xiàn)NR
FILENAME 使用
FILENAME 為awk的內(nèi)置變量,通過下面這個命令,可以看到在每行記錄之前,輸出了當前文件名稱;
awk 'NR==1,NR==3{print FILENAME,$0}' alx.txt
ARGV使用
先來看下面這條命令的執(zhí)行結(jié)果
awk 'NR==1,NR==3{print ARGV[0],ARGV[1],$0}' alx.txt
可以發(fā)現(xiàn),在輸出的每一行記錄前面,拼上了 awk 和 alx.txt這兩個字段,這兩個字段就是這行命令整體解析出來的2個內(nèi)置參數(shù);
自定義變量
看下面這條命令輸出效果,通過-v參數(shù),可以自定義變量進行參數(shù)傳遞;
awk -v myname="zcy" 'BEGIN{print "我的名字是?" ,myname}'
在上文,我們接觸的是awk的輸出功能,主要使用了 print 這個進行輸出,它只能對文本進行簡單的輸出,但是并不能美化或者修改輸出格式;
printf 格式化輸出
如果對C語言有過了解的同學,對printf 并不陌生,使用這個命令(函數(shù))可以對文本進行格式化輸出;
printf與print的幾點區(qū)別
printf 需要指定format;
format 用于指定后面的每個 item輸出格式;
printf 語句不會自動打印換行符; \n ; print 默認添加換行符;
如下,假如我們直接使用 printf 這樣操作,看下效果
awk '{printf $0}' alx.txt
明顯來說,把所有內(nèi)容都輸出到同一行了,這時候,就需要使用 printf的格式化輸出來控制;
awk '{printf "%s\n", $0}' alx.txt
再看一個案例,使用 printf 將文本中的每一列添加前置輸出
awk '{printf "第一列:%s 第二列:%s 第三列:%s\n" ,$1,$2,$3}' alx.txt
上文了解到,awk的語法如下 :
awk [option] ‘pattern[action]’ file …
而且我們了解到,awk是按行處理文本,以上都是關于 print 相關,接下來,聊聊pattern相關的內(nèi)容;
在pattern中,有個比較常見的pattern,BEGIN和END;
BEGIN 模式是處理文本之前需要執(zhí)行的動作;
END模式是處理完成所有的行之后執(zhí)行的操作;
awk 'BEGIN{print "小明在學linux"}'
或者下面這樣
awk 'BEGIN{print "小明在學linux"} {print $0}END{print "處理結(jié)束"}' alx.txt
注意:BEGIN 和 END分別放到處理文本內(nèi)容前后即可
awk如果不指定模式是按行處理,如果指定了模式,只有符合模式的才會被處理
awk常用模式
關系運算符 | 說明 |
---|---|
< | 小于 |
<= | 小于等于 |
== | 等于 |
!= | 不等于 |
>= | 大于等于 |
~ | 匹配正則 |
!~ | 不匹配正則 |
1、打印前三行的文本內(nèi)容
awk 'NR<=3{print $0}' alx.txt
2、匹配密碼文本中含有 zcy 的行
awk '/^zcy/{print $0}' pwd.txt
3、格式化輸出 /etc/passwd 的部分字段
awk -F ":" 'BEGIN{print"用戶名\t\t\t字段1\t\t 字段2\t\t 權限"} {printf "user:%-20s%-20s%-20s%-20s\n", $1,$4,$5,$7}' pwd.txt
4、找出pwd文件中nologin的用戶
awk '/\/sbin\/nologin$/{print NR,$0}' pwd.txt
5、找出 下面這個區(qū)間的文本行
awk '/^daemon/,/^operator/{print NR,$0}' pwd.txt
以上就是“l(fā)inux awk命令如何使用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。