Linux 文本處理利器--Awk常用命令

簡介:

在 Linux/UNIX 系統中,awk 是一個功能強大的編輯工具,逐行讀取輸入文本,並根據指定的匹配模式進行查找,對符合條件的內容進行格式化輸出或者過濾處理,可以在無交互的情況下實現相當複雜的文本操作,被廣泛應用於 Shell 腳本,完成各種自動化配置任務。

工作原理

逐行讀取文本,默認以空格爲分隔符進行分隔,將分隔所得的各個字段保存到內建變量中,並按模式或者條件執行編輯命令

Linux 文本處理利器--Awk常用命令

常見用法:

單引號加上大括號“{}”用於設置對數據進行的處理動作。awk 可以直接處理目標文件,也可以通過“-f”讀取腳本對目標文件進行處理。
awk 將文本文件中的一行視爲一個記錄,而將一行中的某一部分(列)作爲記錄中的一個字(域)。爲了操作這些不同的字段,awk 借用 shell 中類似於位置變量的方法, 用$1、$2、$3…順序地表示行(記錄)中的不同字段。另外 awk 用$0 表示整個行(記錄)。不同的字段之間是通過指定的字符分隔。awk 默認的分隔符是空格。awk 允許在命令行中用“-F 分隔符”的形式來指定分隔符。

命令格式

awk [選項] '模式或條件 {編輯指令}' 文件1 文件2
awk -f 腳本文件 文件1 文件2

特殊的內建變量

FS:指定每行文本的字段分隔符,默認爲空格或製表位(tab鍵);
NF:當前處理的行的字段個數;
NR:當前處理的行的行號(序數);
$0:當前處理的行的整行內容;
$n:當前處理行的第 n 個字段(第 n 列);
FILENAME:被處理的文件名;
RS:數據記錄分隔,默認爲\n,即每行爲一條記錄;

關係運算符號:

只有當條件爲真,才執行指定的動作。
大於(>);小於(<);大於等於(>=);小於等於(<=);
等於(==)、不等於(!=);
&&(與)、||(或)、!(非);
加(+)、減(-)、乘(*)、除(/)、取餘(%)、乘方(^);

示例如下:

打印文本內容

awk '{print $1"---"$2}' aa.txt #在第一和第二字段之間插入--符號

Linux 文本處理利器--Awk常用命令

awk '{print$0}' aa.txt #輸出所有行內容

Linux 文本處理利器--Awk常用命令

awk '/^6/{print}' aa.txt #輸出以6開頭的行

Linux 文本處理利器--Awk常用命令

awk '/^(6|8)/{print}' aa.txt # #輸出以6或8開頭的行

Linux 文本處理利器--Awk常用命令

awk '/^(6)/ && $3 > 70 {print}' aa.txt #輸出以6開頭和第三字段大於70的行

Linux 文本處理利器--Awk常用命令

awk '/^(6)/ && $3 == 55 {print}' aa.txt #輸出以6開頭和第三字段等於60的行

Linux 文本處理利器--Awk常用命令

awk 'NR==1,NR==3{print}' aa.txt #輸出第1至第3行內容
等於awk '(NR>=1)&&(NR<=3){print}' aa.txt

Linux 文本處理利器--Awk常用命令

awk 'NR==1;NR==3{print}' aa.txt #輸出第1行、第3行內容
等於awk 'NR==1 || NR==3{print}' aa.txt

Linux 文本處理利器--Awk常用命令

awk '/^root/{print}' /etc/passwd #輸出以root開頭的行

Linux 文本處理利器--Awk常用命令

按字段輸出文本

awk '{print $1}' aa.txt #輸出第1字段內容

Linux 文本處理利器--Awk常用命令

awk '{print$1,$3}' aa.txt #輸出每行中的第1、3字段

Linux 文本處理利器--Awk常用命令

awk -F ' ' '{print $2}' aa.txt #以空格分割,輸出第二字段

Linux 文本處理利器--Awk常用命令

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章