前段時(shí)間和幾位同事討論過一個(gè)問題:Shell腳本里面怎樣把一個(gè)數(shù)組傳遞到awk內(nèi)部進(jìn)行處理?
當(dāng)時(shí)沒有找到方法。前兩天在QQ群里討論awk的時(shí)候,無意間又聊起這個(gè)話題。機(jī)緣巧合之下找到一個(gè)思路,特此分享。
測(cè)試環(huán)境:
[root]# head -1 /etc/redhat-release
Red Hat Enterprise Linux Server release 6.5 (Santiago)
[root]# awk --version | head -1
GNU Awk 3.1.7
眾所周知,Shell腳本里面把一個(gè)普通變量傳遞給awk是非常簡(jiǎn)單的,直接用 -v 參數(shù)賦值就行了。
str1="Hello World"
awk -v str2="$str1" 'BEGIN{print str2}'
但是,要把一個(gè)數(shù)組傳遞給awk就不是那么簡(jiǎn)單的事情了。請(qǐng)看以下三個(gè)試驗(yàn):
1. 簡(jiǎn)單的數(shù)組可以先賦值后split
arr1=(A B C)
awk -v arr2="${arr1[*]}" 'BEGIN{split(arr2,arr3," "); print arr3[2]}'
2. 有些情況下很難找到合適的分隔符來進(jìn)行split,因?yàn)槟硞€(gè)數(shù)組元素可能會(huì)包含你想用來作為分隔符的那個(gè)字符,這時(shí)split之后無法得到希望的結(jié)果。所以這個(gè)方法不夠嚴(yán)謹(jǐn),尤其是當(dāng)我們無法預(yù)測(cè)數(shù)組元素可能包含哪些字符的時(shí)候。
arr1=(A "B C" D)
awk -v arr2="${arr1[*]}" 'BEGIN{split(arr2,arr3," "); print arr3[2]}'
3. 可以借助export命令和awk的ENVIRON默認(rèn)數(shù)組來實(shí)現(xiàn)這個(gè)功能
arr1=(A "B C" D)
for((i=0;i${#arr1[*]};i++)); do
export arr1_m$i="${arr1[$i]}"
done
awk 'BEGIN{for(i in ENVIRON)if(i~/arr1_m/)print i "=" ENVIRON[i]}'
我這里只是為了演示功能,所以沒有把export變量名的定義和awk內(nèi)部的字符串匹配寫的特別考究,大家可以根據(jù)實(shí)際情況進(jìn)行調(diào)整(比如添加更多的限制條件等)。
結(jié)論:Shell腳本里面把一個(gè)數(shù)組傳遞到awk內(nèi)部進(jìn)行處理,技術(shù)上可行,但不建議在生產(chǎn)環(huán)境上使用。
您可能感興趣的文章:- Linux在shell中自動(dòng)生成1到100的數(shù)組方法(兩種方法)
- Shell 數(shù)組與關(guān)聯(lián)數(shù)組詳解及實(shí)例代碼
- linux shell實(shí)現(xiàn)求一個(gè)多維數(shù)組中的最大和最小值
- shell腳本編程之?dāng)?shù)組
- Linux Shell腳本系列教程(六):數(shù)組和關(guān)聯(lián)數(shù)組
- Shell腳本數(shù)組用法小結(jié)
- Linux shell數(shù)組循環(huán)的實(shí)例詳解