数组总结
目录:
- 数组组成
- 数组赋值
- 数组输出
- 数组案例
1.数组组成
数组的组成就是一个元素的集合,将多个元素利用一个变量存储,避免一个元素采用一个变量而导致形成大量的变量,数组构成由数组名(变量)、元素(变量值)和数组下标组,读取一个数组时采用语法结构为:${变量名[索引编号]},其等价于{$变量名[1]、$变量名[2]..$变量名[n]}。
数组的分类主要分为两类,第一类是普通数组,普通数组索引编号是连续的,申明普通数组采用语法结构:delcare –a 数组名。第二类是关联数组,关联数组是索引编号不连续的的数组,申明关联数组采用语法结构:declare –A 数组名。
2.数组赋值
变量的复制类似for循环中循环取值,可以通过多种方式进行赋值,具体方法如下:
方法1:通过小括号将整数列表直接值赋值给数组
#!/bin/bash declare -a arr arr=( 1 2 3 ) #将定义整数列表赋值 for i in {0..2};do echo "this is the $i times" echo "value=${arr[$i]}" done |
方法:2:通过命令返回值进行
[[email protected] ~/txt]#vim array.sh #!/bin/bash arr=( $(ls /root/txt/) ) for i in {0..2};do echo "this is the $i times" echo "value=${arr[$i]}" done [[email protected] ~/txt]#./array.sh #执行脚本则显示脚本名称,仅仅是脚本名称而已 this is the 0 times value=1.txt this is the 1 times value=2.txt this is the 2 times value=3.txt |
方法3:通过通配符进行赋值
[[email protected] ~/txt]#vim array.sh #!/bin/bash declare -a arr1 arr1=(/root/txt/*.txt) #数组赋值文件,对文件进行处理 for j in {0..2};do echo "this is the $j times" [ -f ${arr1[$j]} ] && echo zunzai || echo bucunzai #通过数组元素判断文件是否存在 lines=`cat ${arr1[$j]} |wc -l` #统计每个文件的行号 let sum+=$lines echo $sum echo "value=${arr1[$j]}" #通过数组显示文件名称 done [[email protected] ~/txt]#./array.sh #验证执行结果 this is the 0 times this is first txt.word value=1.txt this is the 1 times this is sencond txt.word value=2.txt this is the 2 times this is three txt.word value=3.txt |
3.数组输出
数组相当于一系列的变量元素的集合,在数组输出时,可以输出指定的元素、输出整体的元素和元素的个数:
1.输出整体的元素,采用语法结构为${变量名[*|@]},其中*|@表示通配符任意的意思,因此会输出所有的元素。
[[email protected] ~/txt]#intarr=( 1 2 3 ) [[email protected] ~/txt]#echo ${intarr[*]} 1 2 3 |
2.输出指定的元素,采用语法结构为${变量名[索引编号]},其中索引编号从0开始
[[email protected] ~/txt]#intarr=( 1 2 3 ) [[email protected] ~/txt]#echo ${intarr[0]} 1 [[email protected] ~/txt]#echo ${intarr[1]} 2 |
3.在数组中修改其中某一个数组变量的元素或增加一个元素,采用语法结构为:变量名[索引编号]=***,当变量的索引编号存在时,覆盖变量元素原有的值,如若不存在变量的索引编号时,在数组中添加新增的变量元素。
[[email protected] ~/txt]#intarr[1]=20 #存在索引编号1,因此覆盖原有值 [[email protected] ~/txt]#echo ${intarr[1]} 20 [[email protected] ~/txt]#intarr[3]=40 #不存在索引编号3,因此新增变量值 [[email protected] ~/txt]#echo ${intarr[*]} 1 20 3 40 |
4.在数组中将某个元素删除采用语法结构为:unset 数组[索引编号],删除整个数组时:unset数组。
[[email protected] ~/txt]#echo ${intarr[*]} #打印真个数组 1 20 3 40 [[email protected] ~/txt]#unset intarr[3] #删除数组中第4个元素 [[email protected] ~/txt]#echo ${intarr[*]} 1 20 3 [[email protected] ~/txt]#unset intarr #删除真个数组 [[email protected] ~/txt]#echo ${intarr[*]} |
5.在数组中将截取某一段数组元素,语法结构分别为:${数组名[@]:offset:#},offset表示数组偏移个数,#表示取偏移后的多少个元素。
[[email protected] ~/txt]#intarr=({a..z}) #生成序列 [[email protected] ~/txt]#echo ${intarr[*]} a b c d e f g h i j k l m n o p q r s t u v w x y z [[email protected] ~/txt]#echo ${intarr[@]:2:2} #取第2个元素后面的两个元素 c d |
6.在数组中将数组某元素替换,语法结构分别为:${数组名[@]/###/***},offset表示数组中元素为###的替换为***,注意替换的是元素。
[[email protected] ~/txt]#echo ${intarr[*]} a b c d e f g h i j k l m n o p q r s t u v w x y z [[email protected] ~/txt]#echo ${intarr[@]/a/b} #匹配数组元素中的a进行替换为b b b c d e f g h i j k l m n o p q r s t u v w x y z |
4.数组案例
1.循环打印数组元素,数组包含IP地址:192.168.1.110.1.1.1 172.16.0.1;
#!/bin/bash declare -a ip_arr declare -i i=0 declare -i j ip_arr=( #定义数组,数组元素为IP地址,充分说明数组就是变量的集合 192.168.1.1 10.1.1.1 172.16.0.1 ) ############################################### echo “方法1循环打印数组元素” for i in $(seq 0 $[${#ip_arr[*]}-1]);do echo ${ip_arr[$i]} let i++ done ############################################### echo "方法2循环打印数组元素" for (( j=0;j<${#ip_arr[*]};j++)) do echo ${ip_arr[$j]} done ###################将数组作为for循环中的元素进行循环########################## echo "方法3数组遍历打印数组元素" for n in ${ip_arr[*]};do echo $n done |