awk的基本用法
格式
awk 動(dòng)作 文件名/文件名/awk/動(dòng)作
打印當(dāng)前,print 打印,$0當(dāng)前行
[root@zhaocheng ~]# echo "awk is very useful" |awk '{print $0}'
awk is very useful
[root@zhaocheng ~]# cat filetest
root:$1$dDTFylQ3$.vTZKpm7mrra9WMsxvBfW.:18241:0:99999:7
bin:*:17834:0:99999:7:dad
lp:*:17834:0:99999:7ada
sync:*:17834:0:99999:7:::gg
shutdown:*:17834:0:99999:7::da
halt:*:17834:0:99999:7::fsda
nginx:!!:18289::::::daaf
rabbitmq:!!:18297:::::dada
比如取這個(gè)文件的第一個(gè)域
-F 分隔符,":" 以冒號(hào)為分隔符
'{print $1}' 打印第每一列,這里就是以冒號(hào)為分隔符打印每列的第一個(gè)域
[root@zhaocheng ~]# cat filetest |awk -F ":" '{print $1}'
root
bin
lp
sync
shutdown
halt
nginx
rabbitmq
比如以這個(gè)文件打印最后一個(gè)域,這里打印的時(shí)候還是要以什么為分隔符,有的可能是空格
[root@zhaocheng ~]# cat filetest |awk -F ':' '{print $NF}'
7
dad
7ada
gg
da
fsda
daaf
dada
或者取中間的一個(gè)域,可以使用$(NF-1),處理的是-1行從后往前-1
[root@zhaocheng ~]# cat filetest |tail -1
systemctl start mysqld
[root@zhaocheng ~]# cat filetest |tail -1 |awk -F " " '{print $(NF-1)}'
start
或者想知道處理的第幾行,可以使用NR,這里也就是相當(dāng)于加了一個(gè)“)"
[root@zhaocheng ~]# cat filetest|tail -3 |awk -F " " '{print NR ") " $2 }'
1)
2)
3) start
比如取ifconfig的IP,這里取IP的方法比較多
[root@zhaocheng ~]# ip a |grep eth0
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
inet 172.17.0.8/20 brd 172.17.15.255 scope global eth0
這里是先取的打印每列的第2個(gè)域,使用tail -1倒數(shù)第一行,使用awk -F以/為分隔符取第一個(gè)域
[root@zhaocheng ~]# ip a |grep eth0 |awk '{print $2}' |tail -1|awk -F "/" '{print $1}'
172.17.0.8
或者直接使用grep過濾出來,使用awk以空格為分隔符,直接取第二個(gè)域,再取/號(hào)的第一個(gè)域
[root@zhaocheng ~]# ip a |grep eth0 |grep inet |awk -F " " '{print $2}' |awk -F "/" '{print $1}'
172.17.0.8
也可以使用sed取它的行數(shù),再使用awk精確匹配
[root@zhaocheng ~]# ip a |sed -n '9p'|awk -F " " '{print $2}' |awk -F "/" '{print $1}'
172.17.0.8
awk的其他變量
FS:字段分隔符,默認(rèn)是空格和制表符。
RS:行分隔符,用于分割每一行,默認(rèn)是換行符。
OFS:輸出字段的分隔符,用于打印時(shí)分隔字段,默認(rèn)為空格。
ORS:輸出記錄的分隔符,用于打印時(shí)分隔記錄,默認(rèn)為換行符。
OFMT:數(shù)字輸出的格式,默認(rèn)為%.6g。
比如打印出這個(gè)文件中帶有nginx子段的所有行
[root@zhaocheng ~]# awk -F ":" '/nginx/ {print $0}' filetest
nginx:!!:18289::::::daaf
dadad:nginx:sdada
比如打印filetest文件第三行以前的行,以:為分隔符打印第三個(gè)域
[root@zhaocheng ~]# awk -F ":" 'NR >3 {print $3}' filetest
17834
17834
17834
18289
18297
sdada
網(wǎng)站欄目:awk命令常用命令-創(chuàng)新互聯(lián)
地址分享:http://vcdvsql.cn/article0/ccsgoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、企業(yè)網(wǎng)站制作、品牌網(wǎng)站設(shè)計(jì)、自適應(yīng)網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容