参考网址:
linux shell在编程方面比windows 批处理强大太多,无论是在循环、运算以及数据类型方面都是不能比较的。 下面是在数组方面一些操作的总结。
1、数组定义
[hadoop@Master ~]$ a=(1 2 3 4 5)[hadoop@Master ~]$ echo $a1 |
一对括号表示是数组,数组元素用“空格”符号分割开。
2、数组读取与赋值
- 获取长度:
[hadoop@Master ~]$ echo ${#a[@]} 4 |
用${#数组名[@或*]} 可以得到数组长度
- 读取:
[hadoop@Master ~]$ echo ${a[0]} 1[hadoop@Master ~]$ echo ${a[*]}1 2 3 4 |
用${数组名[下标]} 下标是从0开始 下标是:*或者@ 得到整个数组内容
- 赋值:
[hadoop@Master ~]$ a[1]=100 [hadoop@Master ~]$ echo ${a[*]}1 100 3 4[hadoop@Master ~]$ a[3]=100[hadoop@Master ~]$ echo ${a[*]}1 100 3 100[hadoop@Master ~]$ a[4]=100[hadoop@Master ~]$ echo ${a[*]}1 100 3 100 100 |
直接通过 数组名[下标] 就可以对其进行引用赋值,如果下标不存在,自动添加新一个数组元素。
- 删除:
[hadoop@Master ~]$ a=(1 2 3 4 5) [hadoop@Master ~]$ echo ${a[*]}1 2 3 4 5[hadoop@Master ~]$ unset a[hadoop@Master ~]$ echo ${a[*]}[hadoop@Master ~]$ a=(1 2 3 4 5) [hadoop@Master ~]$ unset a[1][hadoop@Master ~]$ echo ${a[*]}1 3 4 5[hadoop@Master ~]$ echo ${#a[*]}4 |
直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。
3、特殊使用
- 分片:
[hadoop@Master ~]$ a=(1 2 3 4 5) [hadoop@Master ~]$ echo ${a[*]:0:3}1 2 3[hadoop@Master ~]$ echo ${a[*]:1:4}2 3 4 5[hadoop@Master ~]$ c=(${a[*]:1:4})[hadoop@Master ~]$ echo ${c[*]:1:4}3 4 5[hadoop@Master ~]$ c=(${a[*]:1:2})[hadoop@Master ~]$ echo ${c[*]:1:1}3 |
直接通过 ${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子:c 就是一个新数据。
- 替换:
[hadoop@Master ~]$ a=(1 2 3 4 5) [hadoop@Master ~]$ echo ${a[@]/3/100}1 2 100 4 5[hadoop@Master ~]$ echo ${a[@]}1 2 3 4 5[hadoop@Master ~]$ a=(${a[@]/3/100})[hadoop@Master ~]$ echo ${a[@]}1 2 100 4 5 |
调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子即加括号赋值变成数组,重新定义数据。