您好,登錄后才能下訂單哦!
首先, 你需要先了解awk 的工作原理:
1。AWK讀取輸入文件一次一行。
2。對于每一行,它匹配在給定的順序模式,如果匹配,執(zhí)行相應(yīng)的動作。
3。如果沒有模式匹配,將執(zhí)行任何行動。
4。在上面的語法,無論是搜索模式,或行動是可選的,但不能同時。
5。如果沒有給出搜索模式,然后awk要執(zhí)行每一行輸入給定的行動。
6。如果沒有給出動作,打印,這是默認(rèn)的操作與模式相匹配的所有行。 7??粘龅娜魏涡袆永ㄌ柺裁炊疾蛔?。它不會執(zhí)行默認(rèn)的打印操作。
8。中的每個行動的聲明應(yīng)該用分號分隔。讓我們創(chuàng)建employee.txt文件,其中有
首先, 你需要先了解awk 的工作原理:
1。AWK讀取輸入文件一次一行。
2。對于每一行,它匹配在給定的順序模式,如果匹配,執(zhí)行相應(yīng)的動作。
3。如果沒有模式匹配,將執(zhí)行任何行動。
4。在上面的語法,無論是搜索模式,或行動是可選的,但不能同時。
5。如果沒有給出搜索模式,然后awk要執(zhí)行每一行輸入給定的行動。
6。如果沒有給出動作,打印,這是默認(rèn)的操作與模式相匹配的所有行。
7。空出的任何行動括號什么都不做。它不會執(zhí)行默認(rèn)的打印操作。
8。中的每個行動的聲明應(yīng)該用分號分隔。
讓我們創(chuàng)建employee.txt文件,其中有以下內(nèi)容,這將是在使用
下文提到的例子。
$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的默認(rèn)行為
默認(rèn)情況下的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與任何參數(shù)的打印輸出默認(rèn)情況下,輸出整行.
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èi)置的變量。對于每一個記錄,即行,分隔空白字符分隔記錄默認(rèn)情況下,它存儲在$ n個變量。如果該行有4個詞,它會被存儲在$ 1,
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 , 由關(guān)鍵詞 BEGIN and END 標(biāo)識
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 --------------
在上面的例子,它打印出的報告和最后文件的標(biāo)題
Awk的范例6。打印技術(shù)部門的雇員列表。
部門名稱現(xiàn)在是第四個字段,所以需要檢查與“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
操作符〜是正則表達(dá)式比較。如果匹配的默認(rèn)操作,即打印整行.
Awk的范例7。打印在技術(shù)部門的雇員人數(shù)
下面的例子, 檢查 department 是否是Technology, 如果是 則Action中,只增加變量的計數(shù). 這個變量在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 部門的員工數(shù)目
總結(jié)
到此這篇關(guān)于shell 里 awk print 的用法詳解的文章就介紹到這了,更多相關(guān)shell awk print用法內(nèi)容請搜索億速云以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持億速云!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。