linux shell数组使用方法总结
linux shell 数组使用方法总结:1.数组定义
$ a=(1 2 3 4 5)
$ echo $a
1
declare -a myarray
在函数中还可以用local 来声明数组
local -a myarray
一对括号表示是数组,数组元素用“空格”符号分割开。
2.数组读取与赋值
[*] 得到长度:
$ echo ${#a[@]}
5
用${#数组名[@或*]} 可以得到数组长度
[*] 读取:
$ echo ${a}
3
$ echo ${a
[*]}
1 2 3 4 5
用${数组名[下标]} 下标是从0开始下标是:*或者@ 得到整个数组内容
[*] 赋值:
$ a=100
$ echo ${a
[*]}
1 100 3 4 5
$ a=100
$ echo ${a
[*]}
1 100 3 4 5 100
直接通过 数组名[下标] 就可以对其进行引用赋值,如果下标不存在,自动添加新一个数组元素
[*] 删除:
$ a=(1 2 3 4 5)
$ unset a
$ echo ${a
[*]}
$ a=(1 2 3 4 5)
$ unset a
$ echo ${a
[*]}
1 3 4 5
$ echo ${#a
[*]}
4
直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。
3.特殊使用
[*] 分片:
$ a=(1 2 3 4 5)
$ echo ${a[@]:0:3}
1 2 3
$ echo ${a[@]:1:4}
2 3 4 5
$ c=(${a[@]:1:4})
$ echo ${#c[@]}
4
$ echo ${c
[*]}
2 3 4 5
#Output in the array subscript greater than 2 elements输出数组中下标大于2的元素
echo ${array[@]:2}
#Output in the array subscript less than 2 elements输出数组中下标小于2的元素
echo ${array[@]::2}
直接通过 ${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子:c 就是一个新数据。
[*] 替换:
$ a=(1 2 3 4 5)
$ echo ${a[@]/3/100}
1 2 100 4 5
$ echo ${a[@]}
1 2 3 4 5
$ a=(${a[@]/3/100})
$ echo ${a[@]}
1 2 100 4 5
调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子,重新定义数据。
从上面讲到的,大家可以发现linux shell 的数组已经很强大了,常见的操作已经绰绰有余了。
转载http://www.cnblogs.com/chengmo/archive/2010/09/30/1839632.html
shell 按行读取并保存成数组
从ip.txt里读取IP.然后把IP地址赋值到一个数组里.
IP文件如下:
Address:220.181.26.163
Address:220.181.26.174
Address:220.181.26.175
Address:220.181.26.176
Address:220.181.19.228
Address:220.181.19.229
Address:220.181.26.161
Address:220.181.26.162
方法一:
for x in ` awk '{print $2}' ip.txt `
{
echo $x
}
方法二:
ARRAY=($(awk '{print $2}' ip.txt))
方法三:
n=0;while read a b;do array[$n]=$b;((n++));done
方法四:
n=1
while ((n
页:
[1]