linux shell 数组有关的一些知识
linux shell 数组有关的一些知识
2人收藏此文章, 我要收藏 发表于7个月前(2012-02-02 18:25) , 已有607次阅读 共0个评论
Linux shell在编程方面比Windows 批处理强大太多,无论是在循环、运算。已经数据类型方面都是不能比较的。 下面是个人在使用时候,对它在数组方面一些操作进行的总结。
1.数组定义
[www.linuxidc.com@linuxidc ~]$ a=(1 2 3 4 5)
[www.linuxidc.com@linuxidc ~]$ echo $a
1
一对括号表示是数组,数组元素用“空格”符号分割开。
2.数组读取与赋值
?得到长度:
[www.linuxidc.com@linuxidc ~]$ echo ${#a[@]}
5
用${#数组名[@或*]} 可以得到数组长度
?读取:
[www.linuxidc.com@linuxidc ~]$ echo ${a[2]}
3
[www.linuxidc.com@linuxidc ~]$ echo ${a} 1 2 3 4 5
用${数组名[下标]} 下标是从0开始 下标是:*或者@ 得到整个数组内容
?赋值:
[www.linuxidc.com@linuxidc ~]$ a[1]=100
[www.linuxidc.com@linuxidc ~]$ echo ${a} 1 100 3 4 5
[www.linuxidc.com@linuxidc ~]$ a[5]=100
[www.linuxidc.com@linuxidc ~]$ echo ${a}
1 100 3 4 5 100
直接通过 数组名[下标] 就可以对其进行引用赋值,如果下标不存在,自动添加新一个数组元素
?删除:
[www.linuxidc.com@linuxidc ~]$ a=(1 2 3 4 5)
[www.linuxidc.com@linuxidc ~]$ unset a
[www.linuxidc.com@linuxidc ~]$ echo ${a}
[www.linuxidc.com@linuxidc ~]$ a=(1 2 3 4 5)
[www.linuxidc.com@linuxidc ~]$ unset a[1]
[www.linuxidc.com@linuxidc ~]$ echo ${a} 1 3 4 5
[www.linuxidc.com@linuxidc ~]$ echo ${#a} 4
直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。
3.特殊使用
?分片:
[www.linuxidc.com@linuxidc ~]$ a=(1 2 3 4 5)
[www.linuxidc.com@linuxidc ~]$ echo ${a[@]:0:3}
1 2 3
[www.linuxidc.com@linuxidc ~]$ echo ${a[@]:1:4}
2 3 4 5
[www.linuxidc.com@linuxidc ~]$ c=(${a[@]:1:4})
[www.linuxidc.com@linuxidc ~]$ echo ${#c[@]}
4
[www.linuxidc.com@linuxidc ~]$ echo ${c} 2 3 4 5
直接通过 ${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子:c 就是一个新数据。
?替换:
[www.linuxidc.com@linuxidc ~]$ a=(1 2 3 4 5)
[www.linuxidc.com@linuxidc ~]$ echo ${a[@]/3/100}
1 2 100 4 5
[www.linuxidc.com@linuxidc ~]$ echo ${a[@]}
1 2 3 4 5
[www.linuxidc.com@linuxidc ~]$ a=(${a[@]/3/100})
[www.linuxidc.com@linuxidc ~]$ echo ${a[@]}
1 2 100 4 5
调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子,重新定义数据。
=================================================================
linux shell 数组有关的一些知识
BASH只支持一维数组,但参数个数没有限制。
声明一个数组:
declare -a array
(其实不用声明,按数组方式直接赋值给变量即可,BASH就知道那是数组)
数组赋值:
(1) array=(var1 var2 var3 ... varN)
(2) array=([0]=var1 [1]=var2 [2]=var3 ... [n]=varN)
(3) array[0]=var1
arrya[1]=var2
...
array[n]=varN
计算数组元素个数:
${#array[@]} 或者 ${#array}
BASH的特殊参数 @ 和 * 都表示“扩展位置参数,从1开始”,但形式稍有差异,但在数组里使用好像是可以通用的。
引用数组:
echo ${array[n]}
遍历数组:
filename=(`ls`)
for var in ${filename[@]};do
echo $var
done
数组实用示例:(个人收集整理)
1、从“标准输入”读入n次字符串,每次输入的字符串保存在数组array里
i=0
n=5
while [ "$i" -lt $n ] ; do
echo "Please input strings ... `expr $i + 1`"
read array[$i]
b=${array[$i]}
echo "$b"
i=`expr $i + 1`
done
2、将字符串里的字母逐个放入数组,并输出到“标准输出”
chars='abcdefghijklmnopqrstuvwxyz'
for (( i=0; i<26; i++ )) ; do
array[$i]=${chars:$i:1}
echo ${array[$i]}
done
这里有趣的地方是 ${chars:$i:1},表示从chars字符串的 $i 位置开始,获取 1 个字符。如果将 1 改为 3 ,就获取 3 个字符啦~ 结果是:
abc
bcd
...
vxy
xyz
yz //没有足够字符串获取了
z //没有足够字符串获取了
3、将数组应用到shell环境变量
3、将数组应用到shell环境变量(1)
数组赋值:
[root@pps ~]# SEASON=("Srping" "Summer" "Autumn" "Winter")
当你发现赋值错了,也可以立刻从新赋值纠正,如上面的 Spring 被写成 Srping。
重新赋值:(原来的值被重写)
[root@pps ~]# SEASON=("Spring" "Summer" "Autumn" "Winter")
查看一下环境变量:
[root@pps ~]# set | grep SEASON
SEASON=([0]="Spring" [1]="Summer" [2]="Autumn" [3]="Winter")
显示整个数组:
[root@pps ~]# echo ${SEASON} 或者 echo ${SEASON[@]} Spring Summer Autumn Winter
显示某一数组元素:
[root@pps ~]# echo ${SEASON[3]}
Winter
给单个数组元素赋值:
[root@pps ~]# SEASON[0]="New_Spring"
再查看一下看数组:
[root@pps ~]# echo ${SEASON} New_Spring Summer Autumn Winter
清除指定的单个数组元素:
[root@pps ~]# unset SEASON[2]
清除整个数组:
[root@pps ~]# unset SEASON
4、将数组应用到shell环境变量(2) 【这个用法不错!给原作者赞一个!】
使用tr命令将文件中的回车转换成空格:
[root@pps ~]# cat /etc/shells | tr "\n" " " > /tmp/tmp.file
将文件中内容给数组赋值:(碰到第一个回车符之前的内容)
[root@pps ~]# read -a SHELLS < /tmp/tmp.file
查看数组赋值情况:
[root@pps ~]# set | grep "SHELLS"
SHELLS=([0]="/bin/sh" [1]="/bin/bash" [2]="/sbin/nologin" [3]="/bin/tcsh" [4]="/bin/csh" [5]="/bin/ksh")
后面可以将这个数组环境变量应用到其它的SHELL脚本或者应用程序里了~