首先, 你需要先瞭解awk 的工作原理:1。AWK讀取輸入檔案一次一行。 2。對於每一行,它匹配在給定的順序模式,如果匹配,執行相應的動作。 3。如果沒有模式比對,將執行任何行動。 4。在上面的文法,無論是搜尋模式,或行動是可選的,但不能同時。 5。如果沒有給出搜尋模式,然後awk要執行每一行輸入給定的行動。 6。如果沒有給出動作,列印,這是預設的操作與模式相匹配的所有行。 7。空出的任何行動括弧什麼都不做。它不會執行預設的列印操作。 8。中的每個行動的聲明應該用分號分隔。讓我們建立employee.txt檔案,其中有
首先, 你需要先瞭解awk 的工作原理:
1。AWK讀取輸入檔案一次一行。
2。對於每一行,它匹配在給定的順序模式,如果匹配,執行相應的動作。
3。如果沒有模式比對,將執行任何行動。
4。在上面的文法,無論是搜尋模式,或行動是可選的,但不能同時。
5。如果沒有給出搜尋模式,然後awk要執行每一行輸入給定的行動。
6。如果沒有給出動作,列印,這是預設的操作與模式相匹配的所有行。
7。空出的任何行動括弧什麼都不做。它不會執行預設的列印操作。
8。中的每個行動的聲明應該用分號分隔。
讓我們建立employee.txt檔案,其中有以下內容,這將是在使用
下文提到的例子。
$cat employee.txt
100 Thomas Manager Sales $5,000
200 Jason Developer Technology $5,500
300 Sanjay Sysadmin Technology $7,000
400 Nisha Manager Marketing $9,500
500 Randy DBA Technology $6,000
Awk的範例1。 awk的預設行為
預設情況下的awk列印檔案的每一行。
1234567
$ awk '{print;}' employee.txt
100 Thomas Manager Sales $5,000
200 Jason Developer Technology $5,500
300 Sanjay Sysadmin Technology $7,000
400 Nisha Manager Marketing $9,500
500 Randy DBA Technology $6,000
在上面的例子中模式中沒有給出。因此,是適用於所有的行。
action與任何參數的列印輸出預設情況下,輸出整行.
Awk的範例2。列印與模式比對的行。
1234$ awk '/Thomas/
> /Nisha/' employee.txt
100 Thomas Manager Sales $5,000
400 Nisha Manager Marketing $9,500
在上面的例子,它列印的“Thomas”或“Nisha”匹配的所有行。它有兩種模式。
Awk的範例3。只列印特定的欄位。
awk有內建的變數。對於每一個記錄,即行,分隔空白字元分隔記錄預設情況下,它儲存在$ n個變數。如果該行有4個詞,它會被儲存在$ 1,$2,$ 3和$ 4。 $0表示整行。 NF是一個內建變數,它代表這一行有多少個被分隔的域.
12345678910111213$ awk '{print $2,$5;}' employee.txt
Thomas $5,000
Jason $5,500
Sanjay $7,000
Nisha $9,500
Randy $6,000
$ awk '{print $2,$NF;}' employee.txt
Thomas $5,000
Jason $5,500
Sanjay $7,000
Nisha $9,500
Randy $6,000
Awk 範例4. 初始化and Final Action
Awk 兩個重要的pattern , 由關鍵詞 BEGIN and END 標識
Syntax:
BEGIN { Actions}
{ACTION} # Action for everyline in a file
END { Actions }
# is for comments in Awk
這是一個例子
12345678910111213
$ awk 'BEGIN {print "Name\tDesignation\tDepartment\tSalary";}
> {print $2,"\t",$3,"\t",$4,"\t",$NF;}
> END{print "Report Generated\n--------------";
> }' employee.txt
Name Designation Department Salary
Thomas Manager Sales $5,000
Jason Developer Technology $5,500
Sanjay Sysadmin Technology $7,000
Nisha Manager Marketing $9,500
Randy DBA Technology $6,000
Report Generated
--------------
在上面的例子,它列印出的報告和最後檔案的標題
Awk的範例6。列印技術部門的僱員列表。
部門名稱現在是第四個欄位,所以需要檢查與“Techology”的字串,如果$4 匹配,則列印這一行
$ awk '$4 ~/Technology/' employee.txt
200 Jason Developer Technology $5,500
300 Sanjay Sysadmin Technology $7,000
500 Randy DBA Technology $6,000
操作符〜是Regex比較。如果匹配的預設操作,即列印整行.
Awk的範例7。列印在技術部門的僱員人數
下面的例子, 檢查 department 是否是Technology, 如果是 則Action中,只增加變數的計數. 這個變數在BEGIN 中被初始化為0
123456
$ awk 'BEGIN { count=0;}
$4 ~ /Technology/ { count++; }
END { print "Number of employees in Technology Dept =",count;}' employee.txt
Number of employees in Tehcnology Dept = 3
在END 中列印出這個變數,就是Technology 部門的員工數目