Linux Shell在編程方面比Windows批處理強大很多,無論是在迴圈、運算。
bash支援一維數組(不支援多維陣列),並且沒有限定數組的大小。類似與C語言,數組元素的下標由0開始編號。擷取數組中的元素要利用下標,下標可以是整數或算術運算式,其值應大於或等於0。
定義數組
在Shell中,用括弧來表示數組,數組元素用“空格”符號分割開。定義數組的一般形式為:
複製代碼 代碼如下:
數組名=(值1 值2 ... 值n)
例如:
複製代碼 代碼如下:
array_name=(value0 value1 value2 value3)
或者
複製代碼 代碼如下:
array_name=(
value0
value1
value2
value3
)
還可以單獨定義數組的各個分量:
複製代碼 代碼如下:
array_name[0]=value0
array_name[1]=value1
array_name[n]=valuen
可以不使用連續的下標,而且下標的範圍沒有限制。
讀取數組
讀取數組元素值的一般格式是:
複製代碼 代碼如下:
${數組名[下標]}
例如:
複製代碼 代碼如下:
valuen=${array_name[n]}
使用@符號可以擷取數組中的所有元素,例如:
複製代碼 代碼如下:
echo ${array_name[@]}
擷取數組的長度
擷取數組長度的方法與擷取字串長度的方法相同,例如:
複製代碼 代碼如下:
# 取得數組元素的個數
length=${#array_name[@]}
# 或者
length=${#array_name[*]}
# 取得數組單個元素的長度
lengthn=${#array_name[n]}
附:shell數組小結
不知道 是什麼時候寫的東西,整理文檔時被考古發現,給那些閑著蛋疼之人,一笑而過吧。如果本文中的錯誤給您帶來所有的精神損失,請找保險公司理陪!當然你可以告訴我 (傾訴)
數組作為一種特殊的資料結構在任何一種程式設計語言中都有它的一席之地,當然bash shell也不例外。本文就shell數組來做一個小的總結。
在這裡只討論一維數組的情況,關於多維陣列(事實上,你得用一維數組的方法來類比),不涉及。這裡包括數組的複製,計算,刪除,替換。
數組的聲明:
複製代碼 代碼如下:
array[key]=value # array[0]=one,array[1]=two
declare -a array # array被當作數組名
array=( value1 value2 value3 ... )
array=( [1]=one [2]=two [3]=three ... )
array="one two three" # echo ${array[0|@|*]},把array變數當作數組來處理,但數組元素只有字串本身
數組的訪問:
複製代碼 代碼如下:
${array[key]} # ${array[1]}
數組的刪除
複製代碼 代碼如下:
unset array[1] # 刪除數組中第一個元素
unset array # 刪除整個數組
計算數組的長度:
複製代碼 代碼如下:
${#array}
${#array[0]} #同上。 ${#array[*]} 、${#array[@]}。注意同#{array:0}的區別
數組的提取
從尾部開始提取:
複製代碼 代碼如下:
array=( [0]=one [1]=two [2]=three [3]=four )
${array[@]:1} # two three four,除掉第一個元素後所有元素,那麼${array[@]:0}表示所有元素
${array[@]:0:2} # one two
${array[@]:1:2} # two three
子串刪除
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@]:0}
one two three four
[root@localhost dev]# echo ${array[@]#t*e} # 左邊開始最短的匹配:"t*e",這將匹配到"thre"
one two e four
[root@localhost dev]# echo ${array[@]##t*e} # 左邊開始最長的匹配,這將匹配到"three"
[root@localhost dev]# array=( [0]=one [1]=two [2]=three [3]=four )
[root@localhost dev]# echo ${array[@] %o} # 從字串的結尾開始最短的匹配
one tw three four
[root@localhost dev]# echo ${array[@] %%o} # 從字串的結尾開始最長的匹配
one tw three four
子串替換
複製代碼 代碼如下:
[root@localhost dev]# array=( [0]=one [1]=two [2]=three [3]=four )
第一個匹配到的,會被刪除
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /o/m}
mne twm three fmur
所有匹配到的,都會被刪除
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@] //o/m}
mne twm three fmur
沒有指定替換子串,則刪除匹配到的子符
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@] //o/}
ne tw three fur
替換字串前端子串
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /#o/k}
kne two three four
替換字串後端子串
複製代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /%o/k}
one twk three four