Linux Shell在編程方面比Windows批處理強(qiáng)大很多,無論是在循環(huán)、運(yùn)算。
bash支持一維數(shù)組(不支持多維數(shù)組),并且沒有限定數(shù)組的大小。類似與C語言,數(shù)組元素的下標(biāo)由0開始編號。獲取數(shù)組中的元素要利用下標(biāo),下標(biāo)可以是整數(shù)或算術(shù)表達(dá)式,其值應(yīng)大于或等于0。
定義數(shù)組
在Shell中,用括號來表示數(shù)組,數(shù)組元素用“空格”符號分割開。定義數(shù)組的一般形式為:
復(fù)制代碼 代碼如下:
數(shù)組名=(值1 值2 ... 值n)
例如:
復(fù)制代碼 代碼如下:
array_name=(value0 value1 value2 value3)
或者
復(fù)制代碼 代碼如下:
array_name=(
value0
value1
value2
value3
)
還可以單獨(dú)定義數(shù)組的各個(gè)分量:
復(fù)制代碼 代碼如下:
array_name[0]=value0
array_name[1]=value1
array_name[n]=valuen
可以不使用連續(xù)的下標(biāo),而且下標(biāo)的范圍沒有限制。
讀取數(shù)組
讀取數(shù)組元素值的一般格式是:
復(fù)制代碼 代碼如下:
${數(shù)組名[下標(biāo)]}
例如:
復(fù)制代碼 代碼如下:
valuen=${array_name[n]}
使用@符號可以獲取數(shù)組中的所有元素,例如:
復(fù)制代碼 代碼如下:
echo ${array_name[@]}
獲取數(shù)組的長度
獲取數(shù)組長度的方法與獲取字符串長度的方法相同,例如:
復(fù)制代碼 代碼如下:
# 取得數(shù)組元素的個(gè)數(shù)
length=${#array_name[@]}
# 或者
length=${#array_name[*]}
# 取得數(shù)組單個(gè)元素的長度
lengthn=${#array_name[n]}
附:shell數(shù)組小結(jié)
不知道 是什么時(shí)候?qū)懙臇|西,整理文檔時(shí)被考古發(fā)現(xiàn),給那些閑著蛋疼之人,一笑而過吧。如果本文中的錯(cuò)誤給您帶來所有的精神損失,請找保險(xiǎn)公司理陪!當(dāng)然你可以告訴我 (傾訴)
數(shù)組作為一種特殊的數(shù)據(jù)結(jié)構(gòu)在任何一種編程語言中都有它的一席之地,當(dāng)然bash shell也不例外。本文就shell數(shù)組來做一個(gè)小的總結(jié)。
在這里只討論一維數(shù)組的情況,關(guān)于多維數(shù)組(事實(shí)上,你得用一維數(shù)組的方法來模擬),不涉及。這里包括數(shù)組的復(fù)制,計(jì)算,刪除,替換。
數(shù)組的聲明:
復(fù)制代碼 代碼如下:
array[key]=value # array[0]=one,array[1]=two
declare -a array # array被當(dāng)作數(shù)組名
array=( value1 value2 value3 ... )
array=( [1]=one [2]=two [3]=three ... )
array="one two three" # echo ${array[0|@|*]},把a(bǔ)rray變量當(dāng)作數(shù)組來處理,但數(shù)組元素只有字符串本身
數(shù)組的訪問:
復(fù)制代碼 代碼如下:
${array[key]} # ${array[1]}
數(shù)組的刪除
復(fù)制代碼 代碼如下:
unset array[1] # 刪除數(shù)組中第一個(gè)元素
unset array # 刪除整個(gè)數(shù)組
計(jì)算數(shù)組的長度:
復(fù)制代碼 代碼如下:
${#array}
${#array[0]} #同上。 ${#array[*]} 、${#array[@]}。注意同#{array:0}的區(qū)別
數(shù)組的提取
從尾部開始提取:
復(fù)制代碼 代碼如下:
array=( [0]=one [1]=two [2]=three [3]=four )
${array[@]:1} # two three four,除掉第一個(gè)元素后所有元素,那么${array[@]:0}表示所有元素
${array[@]:0:2} # one two
${array[@]:1:2} # two three
子串刪除
復(fù)制代碼 代碼如下:
[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} # 從字符串的結(jié)尾開始最短的匹配
one tw three four
[root@localhost dev]# echo ${array[@] %%o} # 從字符串的結(jié)尾開始最長的匹配
one tw three four
子串替換
復(fù)制代碼 代碼如下:
[root@localhost dev]# array=( [0]=one [1]=two [2]=three [3]=four )
第一個(gè)匹配到的,會被刪除
復(fù)制代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /o/m}
mne twm three fmur
所有匹配到的,都會被刪除
復(fù)制代碼 代碼如下:
[root@localhost dev]# echo ${array[@] //o/m}
mne twm three fmur
沒有指定替換子串,則刪除匹配到的子符
復(fù)制代碼 代碼如下:
[root@localhost dev]# echo ${array[@] //o/}
ne tw three fur
替換字符串前端子串
復(fù)制代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /#o/k}
kne two three four
替換字符串后端子串
復(fù)制代碼 代碼如下:
[root@localhost dev]# echo ${array[@] /%o/k}
one twk three four
您可能感興趣的文章:- Shell腳本數(shù)組用法小結(jié)
- linux shell數(shù)組深入學(xué)習(xí)理解
- shell for循環(huán)與數(shù)組應(yīng)用介紹
- linux shell 中數(shù)組的定義和for循環(huán)遍歷的方法
- Linux shell數(shù)組循環(huán)的實(shí)例詳解
- Shell中創(chuàng)建序列和數(shù)組(list、array)的方法
- shell 使用數(shù)組作為函數(shù)參數(shù)的方法(詳解)
- 淺談shell數(shù)組的定義及循環(huán)
- Shell動態(tài)生成數(shù)組的多種方法
- Shell中數(shù)組以及其相關(guān)操作的詳細(xì)實(shí)例