IT培訓(xùn)網(wǎng)
IT在線學(xué)習(xí)
awk命令是Alfred Aho, Peter Weinberger, Brian Kernighan三位作者聯(lián)合開發(fā)的,用于Linux/Unix中處理數(shù)據(jù)和產(chǎn)生報告。awk命令功能十分強大,可根據(jù)需要抓取、截取指定的列或行。
首先在/mnt目錄下創(chuàng)建示例文本文件f1,其內(nèi)容如下:
1 hello hello
2 data data
3 xyz abc
4 123 789
5 ftp
6 Apache
7 apache
然后,使用awk對f1文件內(nèi)容進(jìn)行處理,舉例如下。
①awk -F " " '{print $2,$3}' f1:截取顯示文檔的第二列和第三列,-F指定分隔符為空格,$表示顯示第幾列。其中print表示要做輸出信息的動作,$2和$3表示要輸出的列號,awk要求將print已經(jīng)輸出列等內(nèi)容放在“'{}'”之間。
②awk -F " " '($1>3){print $2,$3}' f1:選取第一列的值大于3的行,顯示其第二列和第三列,在“()”中指定篩選條件。
③awk 'NR==4 || NR==3' f1:顯示第三行和第四行,NR表示行號。
④awk '/data/ {print $2}' f1:抓取包含指定字符的行,再對列進(jìn)行截取。此例中,awk先按照“data”字符串對文件f1中的行篩選,找出包含“data”的行以后,再按照默認(rèn)的空格作為分隔符對行的內(nèi)容做切割,僅打印出第二列的內(nèi)容。
⑤awk '$2 ~ /data/ ' f1:抓取第二列包含指定字符的行。其中“~”表示是否匹配指定的“data”,如果第二列的內(nèi)容包含“data”就打印出整行內(nèi)容。
⑥awk '$2 !~ /data/ ' f1:抓取第二列不包含指定字符的行。其中“!~”表示是否不匹配指定的“data”,如果第二列的內(nèi)容不包含“data”就打印出整行內(nèi)容。
更多內(nèi)容
>>本文地址:http://uj2y2uok.com/zhuanye/2020/59308.html
聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
1 您的年齡
2 您的學(xué)歷
3 您更想做哪個方向的工作?