91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

linux中如何使用awk

發布時間:2021-10-28 17:53:01 來源:億速云 閱讀:124 作者:小新 欄目:系統運維

這篇文章給大家分享的是有關linux中如何使用awk的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

awk 是用于 Unix 和類 Unix 系統的強大文本解析工具,但是由于它有可編程函數,因此你可以用它來執行常規解析任務,因此它也被視為一種編程語言。你可能不會使用 awk 開發下一個 GUI 應用,并且它可能不會代替你的默認腳本語言,但是它是用于特定任務的強大程序。

這些任務或許是驚人的多樣化。了解 awk 可以解決你的哪些問題的最好方法是學習 awk。你會驚訝于 awk 如何幫助你完成更多工作,卻花費更少的精力。

awk 的基本語法是:

awk [options] 'pattern {action}' file

首先,創建此示例文件并將其保存為 colours.txt

name       color  amountapple      red    4banana     yellow 6strawberry red    3grape      purple 10apple      green  8plum       purple 2kiwi       brown  4potato     brown  9pineapple  yellow 5

數據被一個或多個空格分隔為列。以某種方式組織要分析的數據是很常見的。它不一定總是由空格分隔的列,甚至可以不是逗號或分號,但尤其是在日志文件或數據轉儲中,通常有一個可預測的格式。你可以使用數據格式來幫助 awk 提取和處理你關注的數據。

打印列

awk 中,print 函數顯示你指定的內容。你可以使用許多預定義的變量,但是最常見的是文本文件中以整數命名的列。試試看:

$ awk '{print $2;}' colours.txtcolorredyellowredpurplegreenpurplebrownbrownyellow

在這里,awk 顯示第二列,用 $2 表示。這是相對直觀的,因此你可能會猜測 print $1 顯示第一列,而 print $3 顯示第三列,依此類推。

要顯示全部列,請使用 $0

美元符號($)后的數字是表達式,因此 $2$(1+1) 是同一意思。

有條件地選擇列

你使用的示例文件非常結構化。它有一行充當標題,并且各列直接相互關聯。通過定義條件,你可以限定 awk 在找到此數據時返回的內容。例如,要查看第二列中與 yellow 匹配的項并打印第一列的內容:

awk '$2=="yellow"{print $1}' file1.txtbananapineapple

正則表達式也可以工作。此表達式近似匹配 $2 中以 p 開頭跟上任意數量(一個或多個)字符后繼續跟上 p 的值:

$ awk '$2 ~ /p.+p/ {print $0}' colours.txtgrape   purple  10plum    purple  2

數字能被 awk 自然解釋。例如,要打印第三列包含大于 5 的整數的行:

awk '$3>5 {print $1, $2}' colours.txtname    colorbanana  yellowgrape   purpleapple   greenpotato  brown

字段分隔符

默認情況下,awk 使用空格作為字段分隔符。但是,并非所有文本文件都使用空格來定義字段。例如,用以下內容創建一個名為 colours.csv 的文件:

name,color,amountapple,red,4banana,yellow,6strawberry,red,3grape,purple,10apple,green,8plum,purple,2kiwi,brown,4potato,brown,9pineapple,yellow,5

只要你指定將哪個字符用作命令中的字段分隔符,awk 就能以完全相同的方式處理數據。使用 --field-separator(或簡稱為 -F)選項來定義分隔符:

$ awk -F"," '$2=="yellow" {print $1}' file1.csvbananapineapple

保存輸出

使用輸出重定向,你可以將結果寫入文件。例如:

$ awk -F, '$3>5 {print $1, $2} colours.csv > output.txt

這將創建一個包含 awk 查詢內容的文件。

你還可以將文件拆分為按列數據分組的多個文件。例如,如果要根據每行顯示的顏色將 colours.txt 拆分為多個文件,你可以在 awk 中包含重定向語句來重定向每條查詢

$ awk '{print > $2".txt"}' colours.txt

這將生成名為 yellow.txtred.txt 等文件。

感謝各位的閱讀!關于“linux中如何使用awk”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

遂溪县| 孝感市| 钟祥市| 咸宁市| 鄢陵县| 呼玛县| 巴青县| 安阳市| 清涧县| 乌兰浩特市| 陆丰市| 裕民县| 新乐市| 平和县| 金溪县| 新余市| 高密市| 萨迦县| 科技| 社会| 兰西县| 依安县| 印江| 临夏县| 嵩明县| 静宁县| 万山特区| 宜宾县| 泸溪县| 新余市| 航空| 商丘市| 丰镇市| 水城县| 漳平市| 临漳县| 巴塘县| 朔州市| 德兴市| 金堂县| 延川县|