qq591577286 发表于 2018-8-24 13:31:41

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]
查看完整版本: linux shell数组使用方法总结