linux Shell腳本里面把一個數(shù)組傳遞到awk內(nèi)部進行處理
前段時間和幾位同事討論過一個問題: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é)果。所以這個方法不夠嚴謹,尤其是當我們無法預測數(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)境上使用。
相關(guān)文章
Linux Shell 數(shù)組的創(chuàng)建及使用技巧
這篇文章主要介紹了Linux Shell 數(shù)組的創(chuàng)建及使用技巧,本文講解了數(shù)組定義、數(shù)組讀取與賦值以及特殊使用,需要的朋友可以參考下2015-07-07Shell腳本中單引號(‘)和雙引號(“)的使用區(qū)別
這篇文章主要介紹了Shell腳本中單引號(‘)和雙引號(“)的使用區(qū)別,主要探討了變量在單引號和雙引號中的不同,需要的朋友可以參考下2014-06-06shell進程監(jiān)控的實現(xiàn)(ps、sleep、kill)
本文主要介紹了shell進程監(jiān)控的實現(xiàn)(ps、sleep、kill),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06