您的位置:首页 > 运维架构 > Shell

shell for循环和数组应用

2012-07-15 14:25 323 查看
想实现的功能:

读取一个文件,把每一行赋值给一个数组的变量,然后用for循环打印出来

#!/bin/sh

i=1
SUM=`sed -n '$=' tmp.txt` #计算文件的总行数
echo "$SUM"
while read line
do
arr[$i]="$line"
i=`expr $i + 1`
done < tmp.txt
echo "$i"
i=1
for i in `seq $SUM` ;do
echo "${arr[$i]}"
done


下面是在china unix上看到大侠的shell数组的学习

声明数组

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)unset
array # 删除整个数组

计算数组的长度

1)${#array}

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[@] %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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  shell unix