数组的声明:
- 1)array[key]=value # array[0]=one,array[1]=two
复制代码
- 2)declare -a array # array被当作数组名
复制代码
- 3)array=( value1 value2 value3 ... )
复制代码
- 4)array=( [1]=one [2]=two [3]=three ... )
复制代码
- 5)array="one two three" # echo ${array[0|@|*]},把array变量当作数组来处理,但数组元素只有字符串本身
复制代码
数组的访问:
- 1)${array[key]} # ${array[1]}
复制代码
数组的删除
- 1)unset 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
子串删除
- [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
复制代码
push:
array=(”${array[@]}” $new_element)
pop:
array=(${array[@]:0:$((${#array[@]}-1))})
shift:
array=(${array[@]:1})
unshift
array=($new_element “${array[@]}”)
function del_array {
local i
for (( i = 0 ; i < ${#array[@]} ; i++ ))
do
if [ "$1" = "${array[$i]}” ] ;then
break
fi
done
del_array_index $i
}
function del_array_index {
array=(${array[@]:0:$1} ${array[@]:$(($1 + 1))})
}