shell 裡 awk print 的用法

來源:互聯網
上載者:User

首先, 你需要先瞭解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 部門的員工數目

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.