Linux日誌檢視(8)— awk 命令(使用例項)
基本用法
log.txt 文字內容如下:
2 this is a test
3 Are you like awk
This's a test
10 There are orange,apple,mongo
用法一:awk '{[pattern] action}' {filenames}
# 每行按空格或TAB分割,輸出文字中的1、4項
[root@peipei3514 usr]# awk '{print $1,$4}' log.txt
2 a
3 like
This's
10 orange,apple,mongo
# 格式化輸出
[[email protected] usr]# awk ' {printf "%-8s %-10s\n",$1,$4}' log.txt
2 a
3 like
This's
10 orange,apple,mongo
用法二:awk -F
,-F相當於內建變數FS, 指定分割字元
# 使用","分割
[[email protected] usr]# awk -F , '{print $1,$2}' log.txt
2 this is a test
3 Are you like awk
This's a test
10 There are orange apple
# 或者使用內建變數
[[email protected] usr]# awk 'BEGIN{FS=","} {print $1,$2}' log.txt
2 this is a test
3 Are you like awk
This's a test
10 There are orange apple
# 使用多個分隔符。先使用空格分割,然後對分割結果再使用","分割
[[email protected] usr]# awk -F '[ ,]' '{print $1,$2,$5}' log.txt
2 this test
3 Are awk
This's a
10 There apple
用法三:awk -v
,設定變數
[root@peipei3514 usr]# awk -v a=1 '{print $1,$1+a}' log.txt
2 3
3 4
This's 1
10 11
[[email protected] usr]# awk -va=1 -vb=s '{print $1,$1+a,$1b}' log.txt
2 3 2s
3 4 3s
This's 1 This'ss
10 11 10s
用法四:awk -f {awk指令碼} {檔名}
[root@peipei3514 usr]# awk -f cal.awk log.txt
運算子
# 過濾第一列大於2的行
[root@peipei3514 usr]# awk '$1>2' log.txt
3 Are you like awk
This's a test
10 There are orange,apple,mongo
# 過濾第一列等於2的行
[[email protected] usr]# awk '$1==2 {print $1,$3}' log.txt
2 is
# 過濾第一列大於2並且第二列等於'Are'的行
[[email protected] usr]# awk '$1>2 && $2=="Are" {print $1,$2,$3}' log.txt
3 Are you
內建變數
[[email protected] usr]# awk 'BEGIN{printf "%4s %4s %4s %4s %4s %4s %4s %4s %4s\n","FILENAME","ARGC","FNR","FS","NF","NR","OFS","ORS","RS";printf "---------------------------------------------\n"} {printf "%4s %4s %4s %4s %4s %4s %4s %4s %4s\n",FILENAME,ARGC,FNR,FS,NF,NR,OFS,ORS,RS}' log.txt
FILENAME ARGC FNR FS NF NR OFS ORS RS
---------------------------------------------
log.txt 2 1 5 1
log.txt 2 2 5 2
log.txt 2 3 3 3
log.txt 2 4 4 4
[[email protected] usr]# awk -F\' 'BEGIN{printf "%4s %4s %4s %4s %4s %4s %4s %4s %4s\n","FILENAME","ARGC","FNR","FS","NF","NR","OFS","ORS","RS";printf "---------------------------------------------\n"} {printf "%4s %4s %4s %4s %4s %4s %4s %4s %4s\n",FILENAME,ARGC,FNR,FS,NF,NR,OFS,ORS,RS}' log.txt
FILENAME ARGC FNR FS NF NR OFS ORS RS
---------------------------------------------
log.txt 2 1 ' 1 1
log.txt 2 2 ' 1 2
log.txt 2 3 ' 2 3
log.txt 2 4 ' 1 4
[[email protected] usr]# awk '{print NR,FNR,$1,$2,$3}' log.txt
1 1 2 this is
2 2 3 Are you
3 3 This's a test
4 4 10 There are
[[email protected] usr]# awk '{print $1,$2,$5}' OFS=" $ " log.txt
2 $ this $ test
3 $ Are $ awk
This's $ a $
10 $ There $
使用正則,字串匹配
# 輸出第二列包含 "th",並列印第二列與第四列
# ~ 表示模式開始。// 中是模式。
[[email protected] usr]# awk '$2 ~ /th/ {print $2,$4}' log.txt
this a
# 輸出包含"re" 的行
[[email protected] usr]# awk '/re/ ' log.txt
3 Are you like awk
10 There are orange,apple,mongo
忽略大小寫
[root@peipei3514 usr]# awk 'BEGIN{IGNORECASE=1} /this/' log.txt
2 this is a test
This's a test
模式取反
[root@peipei3514 usr]# awk '$2 !~ /th/ {print $2,$4}' log.txt
Are like
a
There orange,apple,mongo
[root@peipei3514 usr]# awk '!/th/ {print $2,$4}' log.txt
Are like
a
There orange,apple,mongo
awk指令碼
關於awk指令碼,我們需要注意兩個關鍵詞BEGIN和END。
- BEGIN{ 這裡面放的是執行前的語句 }
- {這裡面放的是處理每一行時要執行的語句}
- END {這裡面放的是處理完所有的行後要執行的語句 }
假設有這麼一個檔案(學生成績表):
$ cat score.txt
Marry 2143 78 84 77
Jack 2321 66 78 45
Tom 2122 48 77 71
Mike 2537 87 97 95
Bob 2415 40 57 62
我們的awk指令碼如下:
#!/bin/awk -f
#執行前
BEGIN {
math = 0
english = 0
computer = 0
printf "NAME NO. MATH ENGLISH COMPUTER TOTAL\n"
printf "---------------------------------------------\n"
}
#執行中
{
math+=$3
english+=$4
computer+=$5
printf "%-6s %-6s %4d %8d %8d %8d\n", $1, $2, $3,$4,$5, $3+$4+$5
}
#執行後
END {
printf "---------------------------------------------\n"
printf " TOTAL:%10d %8d %8d \n", math, english, computer
printf "AVERAGE:%10.2f %8.2f %8.2f\n", math/NR, english/NR, computer/NR
}
我們來看一下執行結果:
[[email protected] usr]# awk -f cal.awk score.txt
NAME NO. MATH ENGLISH COMPUTER TOTAL
---------------------------------------------
Marry 2143 78 84 77 239
Jack 2321 66 78 45 189
Tom 2122 48 77 71 196
Mike 2537 87 97 95 279
Bob 2415 40 57 62 159
---------------------------------------------
TOTAL: 319 393 350
AVERAGE: 63.80 78.60 70.00
另外一些例項
AWK的hello world程式為:
BEGIN { print "Hello, world!" }
計算檔案大小
$ ls -l *.txt | awk '{sum+=$6} END {print sum}'
--------------------------------------------------
666581
從檔案中找出長度大於80的行
awk 'length>80' log.txt
列印九九乘法表
[root@peipei3514 usr]# seq 9 | sed 'H;g' | awk -v RS='' '{for(i=1;i<=NF;i++)printf("%dx%d=%d%s", i, NR, i*NR, i==NR?"\n":"\t")}'
1x1=1
1x2=2 2x2=4
1x3=3 2x3=6 3x3=9
1x4=4 2x4=8 3x4=12 4x4=16
1x5=5 2x5=10 3x5=15 4x5=20 5x5=25
1x6=6 2x6=12 3x6=18 4x6=24 5x6=30 6x6=36
1x7=7 2x7=14 3x7=21 4x7=28 5x7=35 6x7=42 7x7=49
1x8=8 2x8=16 3x8=24 4x8=32 5x8=40 6x8=48 7x8=56 8x8=64
1x9=9 2x9=18 3x9=27 4x9=36 5x9=45 6x9=54 7x9=63 8x9=72 9x9=81
相關推薦
Linux日誌檢視(8)— awk 命令(使用例項)
基本用法 log.txt 文字內容如下: 2 this is a test 3 Are you like awk This's a test 10 There are orange,apple,mongo 用法一:awk '{[pattern] actio
Linux日誌檢視(9)— grep 命令(詳解+例項)
概述 grep(global search regular expression(RE) and print out the line,全面搜尋正則表示式並把行打印出來)是一種強大的文字搜尋工具,它能
Linux日誌檢視(5)— more 命令
more命令是一個基於vi編輯器文字過濾器,它以全螢幕的方式按頁顯示文字檔案的內容,支援vi中的關鍵字定位操作。more名單中內建了若干快捷鍵,常用的有H(獲得幫助資訊),Enter(向下翻滾一行),空格(向下滾動一屏),Q(退出命令)。more命令從前向後讀取
【Linux】基礎每日一命之awk命令(上)
設置變量 兩個 oob 每日 gin water 不能 -o source awk 是一個強大的文本分析工具 語法:awk [選項參數] ‘script‘ var=value file(s)或awk [選項參數] -f scriptfile var=value file(s
Linux awk命令(一)基礎
awk 是一種程式語言,用於在linux/unix下對文字和資料進行處理,它能提供一個類程式設計環境來修改和組織檔案中的資料。它比sed功能更為強大,可以看看sed的使用: Linux sed命令(一)基礎 Linux sed命令(二)進階 awk分別代表其作者姓氏的第一個字母,它
Linux命令(36)——awk命令
1.簡介 AWK是一個優良的文字處理工具,Linux及Unix環境中現有的功能最強大的資料處理引擎之一。資料可以來自標準輸入(stdin)、一個或多個檔案,或其它命令的輸出。它支援使用者自定義函式和動態正則表示式等先進功能,是linux/unix下的一個強大程
linux初級運維 之目錄管理命令(ls,cd,pwd,mkdir)
linux 入門 ls命令:-list directory contents 命令描述:列出目錄內容 常用命令選項 -l:使用詳細格式列表。 -a:列出所有的文件和目錄(用來顯示以.開頭的隱藏文件)。 -A:顯示所有文件和目錄但不包括.和..(.表示
linux文件與目錄管理相關命令(上)
文件時間 額外 print num sys direct base -- 文件的時間 學習一下linux文件與目錄管理相關命令 pwd,cd,ls,touch,stat,basename,dirname,cp,mv,rm,tree,mkdir,rmdir,ln,file p
Linux工作中常用到的一些命令(持續更新)常用的
args 10g $1 conf 運行級別 who 快速 以及 awk 1、查看運行級別3開啟的服務列表: chkconfig --list|grep 3:on 2、查找某類型的文件並計算總大小。 find / -name *.conf -exec w
Linux(Ubuntu)常用命令(三)
需要 ip地址 useradd 賬號 his word color -a change 查看時間 cal :顯示當前日期。 cal 2018 :顯示全年日歷。/ cal -y 顯示當年日歷。 date :顯示當前時間。 這幾個一般不會用到了解即可。 查
linux 日常中會用到的命令(持續更新)
xargs gre 目錄 技術 所有 圖片 更新 ima alt 1. grep 比如,我要查看www目錄下所有包含 “聊天室” 的文件 grep -rn "聊天室" * 比如我要把 www 目錄下所有文件中的 聊天室 替換為 哈哈
Linux學習歷程——Centos 7 賬戶管理命令(使用者篇)useradd usermod userdel
一、命令介紹 useradd 用於建立新的使用者 usermod 用於修改使用者屬性 userdel 用於刪除使用者 --------------------
Linux命令(49)——export命令(builtin)
1.命令簡介 export命令為Shell內建命令,用於設定或顯示環境變數,環境變數包含變數與函式。 在Shell中執行程式時,Shell會提供一組環境變數。export可新增、刪除或修改環境變數,供後續被執行的程式使用。export的作用效果僅限於當前登陸。 2.命令格式
python——awk命令(1)
awk是一個報告生成器,擁有強大的文字格式化的能力。可以把報告理解成“報表”或“表格”。利用awk的“文字格式化能力”將一些文字整理成我們想要的樣子。 awk基本語法:awk [options] 'Pattern{Action}' file 從字面上理解 ,actio
Linux下檢視檔案和資料夾大小(df&du)
df 用法:df [選項]… [檔案]… 顯示每個檔案所在的檔案系統的資訊,預設顯示全部的檔案系統 常用選項 -h, –human-readable 大小顯示為人類易讀形式 (e.g., 1K
Linux 刪除資料夾和檔案的命令(強制刪除包括非空檔案)
linux刪除目錄很簡單,很多人還是習慣用rmdir,不過一旦目錄非空,就陷入深深的苦惱之中,現在使用rm -rf命令即可。直接rm就可以了,不過要加兩個引數-rf 即:rm -rf 目錄名字-r 就
Linux(CentOS7)常用命令(持續更新中)
1)命令後帶-與--的引數區別: 引數用一橫的說明後面的引數是字元形式。引數用兩橫的說明後面的引數是單詞形式。 引數前有橫的是 System V風格。引數前沒有橫的是 BSD風格。 有關System V和BSD的其他區別: 系統啟動過程中 kernel 最後一步呼叫的
linux下獲取磁碟使用情況的命令 (df du )
1、前言 在嵌入式裝置中,硬碟空間非常有限,在涉及到經常寫日誌的程序時候,需要考慮日誌的大小和刪除,不然很快就硬碟寫滿,導致日誌程式崩潰。為了捕獲硬碟寫滿的異常場景,我們需要在寫日誌過程中判斷硬碟空間的使用情況,根據硬碟的使用情況,就可以判斷是否寫滿了。如果將要寫滿了,
常用awk命令(轉)
awk 用法:awk ' pattern {action} ' 變數名 含義 ARGC 命令列變元個數 ARGV 命令列變元陣列 FILENAME 當前輸入檔名 FNR 當前檔案中的記錄號 FS 輸入域分隔符,預設為一個空格 RS 輸入記錄分隔符 NF 當前記錄裡域個數 NR 到目前為止記錄數 OFS 輸出
Linux(CentOS)常用命令(三) —— 檔案操作命令
1、cp :(copy)複製檔案或資料夾到指定目錄 cp (空)資料夾或檔名 /指定目錄 cp (空)資料夾或檔名 /指定目錄/要更改的名稱 當要複製的資料夾不為空時,要加上引數 -r 或