主頁 > 知識庫 > Shell腳本數(shù)組操作小結(jié)

Shell腳本數(shù)組操作小結(jié)

熱門標(biāo)簽:地圖標(biāo)注超出范圍怎么辦 東莞電銷機(jī)器人價格一覽表 佛山高德地圖標(biāo)注中心 旅游地圖標(biāo)注大全 百度地圖的地圖標(biāo)注 陜西電銷卡外呼系統(tǒng)怎么安裝 excel地址地圖標(biāo)注 百度地圖標(biāo)注圖標(biāo)更換 杭州機(jī)器人外呼系統(tǒng)

Linux Shell在編程方面比Windows批處理強(qiáng)大很多,無論是在循環(huá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
)

還可以單獨定義數(shù)組的各個分量:

復(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ù)組元素的個數(shù)
length=${#array_name[@]}
# 或者
length=${#array_name[*]}
# 取得數(shù)組單個元素的長度
lengthn=${#array_name[n]}

附:shell數(shù)組小結(jié)

不知道 是什么時候?qū)懙臇|西,整理文檔時被考古發(fā)現(xiàn),給那些閑著蛋疼之人,一笑而過吧。如果本文中的錯誤給您帶來所有的精神損失,請找保險公司理陪!當(dāng)然你可以告訴我 (傾訴)

數(shù)組作為一種特殊的數(shù)據(jù)結(jié)構(gòu)在任何一種編程語言中都有它的一席之地,當(dāng)然bash shell也不例外。本文就shell數(shù)組來做一個小的總結(jié)。
在這里只討論一維數(shù)組的情況,關(guān)于多維數(shù)組(事實上,你得用一維數(shù)組的方法來模擬),不涉及。這里包括數(shù)組的復(fù)制,計算,刪除,替換。

數(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ù)組中第一個元素

unset array # 刪除整個數(shù)組

計算數(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,除掉第一個元素后所有元素,那么${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 )

第一個匹配到的,會被刪除

復(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)的實例詳解
  • Shell中創(chuàng)建序列和數(shù)組(list、array)的方法
  • shell 使用數(shù)組作為函數(shù)參數(shù)的方法(詳解)
  • 淺談shell數(shù)組的定義及循環(huán)
  • Shell動態(tài)生成數(shù)組的多種方法
  • Shell中數(shù)組以及其相關(guān)操作的詳細(xì)實例

標(biāo)簽:隨州 南充 西藏 通遼 朝陽 青島 雅安 延邊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Shell腳本數(shù)組操作小結(jié)》,本文關(guān)鍵詞  Shell,腳本,數(shù)組,操作,小結(jié),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Shell腳本數(shù)組操作小結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Shell腳本數(shù)組操作小結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章