前段時間和幾位同事討論過一個問題:Shell腳本里面怎樣把一個數(shù)組傳遞到awk內(nèi)部進行處理?
當時沒有找到方法。前兩天在QQ群里討論awk的時候,無意間又聊起這個話題。機緣巧合之下找到一個思路,特此分享。
測試環(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腳本里面把一個普通變量傳遞給awk是非常簡單的,直接用 -v 參數(shù)賦值就行了。
str1="Hello World"
awk -v str2="$str1" 'BEGIN{print str2}'
但是,要把一個數(shù)組傳遞給awk就不是那么簡單的事情了。請看以下三個試驗:
1. 簡單的數(shù)組可以先賦值后split
arr1=(A B C)
awk -v arr2="${arr1[*]}" 'BEGIN{split(arr2,arr3," "); print arr3[2]}'
2. 有些情況下很難找到合適的分隔符來進行split,因為某個數(shù)組元素可能會包含你想用來作為分隔符的那個字符,這時split之后無法得到希望的結(jié)果。所以這個方法不夠嚴謹,尤其是當我們無法預(yù)測數(shù)組元素可能包含哪些字符的時候。
arr1=(A "B C" D)
awk -v arr2="${arr1[*]}" 'BEGIN{split(arr2,arr3," "); print arr3[2]}'
3. 可以借助export命令和awk的ENVIRON默認數(shù)組來實現(xiàn)這個功能
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ù)實際情況進行調(diào)整(比如添加更多的限制條件等)。
結(jié)論:Shell腳本里面把一個數(shù)組傳遞到awk內(nèi)部進行處理,技術(shù)上可行,但不建議在生產(chǎn)環(huán)境上使用。
您可能感興趣的文章:- Linux在shell中自動生成1到100的數(shù)組方法(兩種方法)
- Shell 數(shù)組與關(guān)聯(lián)數(shù)組詳解及實例代碼
- linux shell實現(xiàn)求一個多維數(shù)組中的最大和最小值
- shell腳本編程之數(shù)組
- Linux Shell腳本系列教程(六):數(shù)組和關(guān)聯(lián)數(shù)組
- Shell腳本數(shù)組用法小結(jié)
- Linux shell數(shù)組循環(huán)的實例詳解