首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

shell学习之数组运用技巧

2012-09-03 
shell学习之数组使用技巧数组的使用$ a(1 2 3 4 5) $ echo $a 1 一对括号表示是数组,数组元素用“空格”符

shell学习之数组使用技巧

数组的使用
$ a=(1 2 3 4 5)
$ echo $a
1
一对括号表示是数组,数组元素用“空格”符号分割开。
数组读取与赋值
得到长度:
$ echo ${#a[@]}
5
用${#数组名[@或*]} 可以得到数组长度
读取:
$ echo ${a[2]}?
3
$ echo ${a[*]}?
1 2 3 4 5???
用${数组名[下标]} 下标是从0开始? 下标是:*或者@ 得到整个数组内容
赋值:
$ a[1]=100
$ echo ${a[*]}?
1 100 3 4 5
$ a[5]=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[1]??
$ echo ${a[*]}
1 3 4 5
$ echo ${#a[*]}
4
直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。
特殊使用
分片:
$ 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
直接通过${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子: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 的数组已经很强大了,常见的操作已经绰绰有余了
这里主要以一个求和计算的题目为,介绍使用seq动态生成数组系列
样例进行分析
题目:请用linux shell 写一段脚本,实现从1..1000中所有偶数的和值。
方法一: 通过
while 循环得到需要的结果:
start=1;
total=0;
while [ $start -le 1000 ];do
??? [[ $(($start%2)) == 0 ]]&&total=$(($total+$start));
?? start=$(($start+1));
done;
echo $total;
[chengmo@centos5 ~]$ start=1;total=0;while [ $start -le 1000 ];do??? [[ $(($start%2)) == 0 ]]&&total=$(($total+$start));?? start=$(($start+1));done;echo $total;
250500
以上运行结果是:250500,在linux shell 中,”;”作为命令行分隔符。如果大家对于$(()) 运算符号不是很理解,可以查看:linux shell 实现四则运算。
http://czmmiao.iteye.com/blog/1439397
也可以参考另外一篇文章linux shell 逻辑运算符、逻辑表达式详解。
http://czmmiao.iteye.com/blog/1439403
方法二:通过for 循环得到结果:
start=0;
total=0;
for i in $(seq $start 2 1000); do
??? total=$(($total+$i));
done;
echo $total;
[chengmo@centos5 ~]$ start=0;total=0;for i in $(seq $start 2 1000); do? total=$(($total+$i));done;echo $total;????????
250500
上面语句已经代码方面明显优于方法一,而且性能方面表现也很好。下面比较性能就可以发现:
[chengmo@centos5 ~]$ time (start=0;total=0;for i in $(seq $start 2 1000);
do??? total=$(($total+$i));done;echo $total;)????????????
250500
real??? 0m0.016s
user??? 0m0.012s
sys???? 0m0.003s
$ time (start=1;total=0;while [ $start -le 1000 ];do??? [[ $(($start%2)) == 0 ]]&&total=$(($total+$start));?? start=$(($start+1));done;echo $total;)?
250500
real??? 0m0.073s
user??? 0m0.069s
sys???? 0m0.004s
方法一耗时是方法二的6倍!
seq 使用
seq [OPTION]... LAST
seq [OPTION]... FIRST LAST
seq [OPTION]... FIRST INCREMENT LAST
$seq 1000?? ‘起始默认是 1,间隔默认也是1
$seq 2 1000? ‘间隔默认是1
$seq 1 3 10??? '从1开始,到10 间隔为3 结果是:1 4 7 10 说明:默认间隔是
“空格” 如果想换成其它的可以带参数:-s
$seq -s'#' 1 3 10
1#4#7#10
应用技巧:
生成连续数组系列:
$ a=($(seq? 1 3 10))????
$ echo ${a[1]}
4
$ echo ${a[@]}
1 4 7 10
生成连续相同字符:
$ seq -s '#' 30 | sed -e 's/[0-9]*//g'
#############################
上面例子:通过加入间隔字符‘#’后,替换掉数字, 生成连续相同字符’#’,这个在以后书写中还是有不少帮助。


参考至:http://wenku.baidu.com/view/d5d06b5bbe23482fb4da4c0c.html

如有错误,欢迎指正

邮箱:czmcj@163.com

热点排行