读取一个文件,把每一行赋值给一个数组的变量,然后用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
附: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}的区别
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | #!/bin/bash arg1=(`cat /root/1`) arg2=(`awk ‘{print $2}’ /root/2`) n=0 if [ ${#arg1[*]} -ge ${#arg2[*]} ];then x=${#arg1[*]} for ((n=0;n<$x;n++)) do echo ${arg1[$n]} ${arg2[$n]} done else x=${#arg2[*]} for ((n=0;n<$x;n++)) do echo ${arg1[$n]} ${arg2[$n]} done fi unset arg1 unset arg2 |
上面脚本用到的两个文件的内容是:
[root@localhost ~]# cat 1
1
2
3
4
5
[root@localhost ~]# cat 2
1 a
2 b
3 c
4 d
5 e
6 f
这里主要就是用到了判断两个数组长度并对比。上面arg1数组和arg2数组比长度,得出的结论是arg1数组共有5个元素,而arg2数组共有6个元素,所以设置for循环的循环次数为arg2数组的长度。
其他应用代码:
01 | arr_A=(1 2) |
02 | arr_B=(3 4) |
03 | arr_C=(3 4 5) |
04 |
05 | tmp=”A B C” |
06 | for char in $tmp |
07 | do |
08 | var=”arr_”${char}”[@]” |
09 | for i in ${!var} |
10 | do |
11 | echo $i |
12 | done |
13 | done |