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