shell数组小结

数组作为一种特殊的数据结构在任何一种编程语言中都有它的一席之地,当然bash shell也不例外。本文就shell数组来做一个小的总结。
在这里只讨论一维数组的情况,关于多维数组(事实上,你得用一维数组的方法来模拟),不涉及。这里包括数组的复制,计算,删除,替换。

数组的声明:

  1. 1)array[key]=value # array[0]=one,array[1]=two


  1. 2)declare -a array # array被当作数组名


  1. 3)array=( value1 value2 value3 ... )


  1. 4)array=( [1]=one [2]=two [3]=three ... )


  1. 5)array="one two three" # echo ${array[0|@|*]},把array变量当作数组来处理,但数组元素只有字符串本身


数组的访问:

  1. 1)${array[key]} # ${array[1]}


数组的删除

  1. 1)unset array[1] # 删除数组中第一个元素

  2. 2)unset array # 删除整个数组


计算数组的长度:

  1. 1)${#array}


  1. 2)${#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

子串删除

  1. [root@localhost dev]# echo ${array[@]:0}

  2. one two three four


  1. [root@localhost dev]# echo ${array[@]#t*e} # 左边开始最短的匹配:"t*e",这将匹配到"thre"

  2. one two e four


  1. [root@localhost dev]# echo ${array[@]##t*e} # 左边开始最长的匹配,这将匹配到"three"


  1. [root@localhost dev]# array=( [0]=one [1]=two [2]=three [3]=four )


  1. [root@localhost dev]# echo ${array[@] %o} # 从字符串的结尾开始最短的匹配

  2. one tw three four


  1. [root@localhost dev]# echo ${array[@] %%o} # 从字符串的结尾开始最长的匹配

  2. one tw three four


子串替换

  1. [root@localhost dev]# array=( [0]=one [1]=two [2]=three [3]=four )


第一个匹配到的,会被删除

  1. [root@localhost dev]# echo ${array[@] /o/m}

  2. mne twm three fmur


所有匹配到的,都会被删除

  1. [root@localhost dev]# echo ${array[@] //o/m}

  2. mne twm three fmur


没有指定替换子串,则删除匹配到的子符

  1. [root@localhost dev]# echo ${array[@] //o/}

  2. ne tw three fur


替换字符串前端子串

  1. [root@localhost dev]# echo ${array[@] /#o/k}

  2. kne two three four


替换字符串后端子串

  1. [root@localhost dev]# echo ${array[@] /%o/k}

  2. one twk three four


你可能感兴趣的:(linux系统)