awk小技巧之執行shell命令

raysuen發表於2021-08-12
方法一:system函式
ip add | grep enp0s8 | grep inet | awk '{print $2}' | awk -F"/" '{printf $1" "}{cmd="hostname";system(cmd)}
[root@rac1 ~]# ls | awk '{printf $NF" "}{cmd="hostname";system(cmd)}

方法二:使用變數(獲取變數的時候已經執行命令)
ls |awk '{print i$0}' i= `pwd`'/'
[root@rac1 ~]# ls -a |awk '{print i$0}' i= "`pwd`/"  注意:這裡的雙引號不可以用單引號替換,單引號內強制為字串-不執行引號內的命令。
[root@rac1 ~]# ls -a |awk -v i="`pwd`/" '{print i$0}'
方法三:把命令傳遞給bash
[root@rac1 ~]# awk 'BEGIN{print "echo cange"|"bash"}'   
cang
[root@rac1 ~]# ls -lh | awk '{print "echo cange"|"bash"}'
cange
cange
cange
cange
cange
cang
方法三的內容延伸:執行多重命令
[root@rac1 ~]# ls -lh | awk '{print "echo cange `date +%Y-%m-%d`"}' | bash
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-1
[root@rac1 ~]# ls -lh | awk '{print "echo cange $(date +%Y-%m-%d)"}'| bash 
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
cange 2021-08-11
結合輸出引號和shell命令:
[grid@rac1 ~]$ find $ORACLE_BASE/diag/crs/`hostname`/crs/trace/ -ctime -1 | awk '{print "echo "$0" ` stat -c""\"" "%X %Y %Z" "\""" "$0"`"}' | head -n 10 | bash
/u01/app/grid/diag/crs/rac1/crs/trace/ 1628211140 1628211123 1628211123
/u01/app/grid/diag/crs/rac1/crs/trace/ocssd.trc 1628153326 1628211421 1628211421
/u01/app/grid/diag/crs/rac1/crs/trace/ocssd.trm 1628153326 1628211421 1628211421
/u01/app/grid/diag/crs/rac1/crs/trace/octssd.trc 1628099149 1628211410 1628211410
/u01/app/grid/diag/crs/rac1/crs/trace/octssd.trm 1628099149 1628211410 1628211410
/u01/app/grid/diag/crs/rac1/crs/trace/ohasd_orarootagent_root.trc 1628206771 1628211421 1628211421
/u01/app/grid/diag/crs/rac1/crs/trace/crsd_oraagent_grid.trc 1628044975 1628211421 1628211421
/u01/app/grid/diag/crs/rac1/crs/trace/ohasd.trc 1628202286 1628211419 1628211419
/u01/app/grid/diag/crs/rac1/crs/trace/crsd.trc 1628115223 1628211414 1628211414
/u01/app/grid/diag/crs/rac1/crs/trace/crsd_oraagent_oracle.trc 1627639317 1628211417 162821141
##%分號可以放在雙引號內正常輸出,


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28572479/viewspace-2786529/,如需轉載,請註明出處,否則將追究法律責任。

相關文章