• linux shell 数组建立及使用技巧


    参考:http://www.cnblogs.com/chengmo/archive/2010/09/30/1839632.html

    linux shell在编程方面比windows 批处理强大太多,无论是在循环、运算。已经数据类型方面都是不能比较的。 下面是个人在使用时候,对它在数组方面一些操作进行的总结。

    1. 数组定义

    [chengmo@centos5 ~]$ a=(1 2 3 4 5)
    [chengmo@centos5 ~]$ echo $a
    1

    一对括号表示是数组,数组元素用“空格”符号分割开。

    2. 数组读取与赋值

    2.1 得到长度

    [chengmo@centos5 ~]$ echo ${#a[@]}
    5

    用${#数组名[@或*]} 可以得到数组长度

    2.2 读取

    [chengmo@centos5 ~]$ echo ${a[2]} 
    3
    [chengmo@centos5 ~]$ echo ${a[*]} 
    1 2 3 4 5  

    用${数组名[下标]} 下标是从0开始  下标是:*或者@ 得到整个数组内容

    2.3 赋值:

    [chengmo@centos5 ~]$ a[1]=100
    [chengmo@centos5 ~]$ echo ${a[*]} 
    1 100 3 4 5
    [chengmo@centos5 ~]$ a[5]=100     
    [chengmo@centos5 ~]$ echo ${a[*]}
    1 100 3 4 5 100

    直接通过 数组名[下标] 就可以对其进行引用赋值,如果下标不存在,自动添加新一个数组元素

    2.4 删除:

    [chengmo@centos5 ~]$ a=(1 2 3 4 5)
    [chengmo@centos5 ~]$ unset a
    [chengmo@centos5 ~]$ echo ${a[*]}
    [chengmo
    @centos5 ~]$ a=(1 2 3 4 5) [chengmo@centos5 ~]$ unset a[1] [chengmo@centos5 ~]$ echo ${a[*]} 1 3 4 5 [chengmo@centos5 ~]$ echo ${#a[*]} 4

    直接通过:unset 数组[下标] 可以清除相应的元素,不带下标,清除整个数据。

    3.特殊使用

    3.1 分片:

    [chengmo@centos5 ~]$ a=(1 2 3 4 5)
    [chengmo@centos5 ~]$ echo ${a[@]:0:3}
    1 2 3
    [chengmo@centos5 ~]$ echo ${a[@]:1:4}
    2 3 4 5
    [chengmo@centos5 ~]$ c=(${a[@]:1:4})
    [chengmo@centos5 ~]$ echo ${#c[@]}
    4
    [chengmo@centos5 ~]$ echo ${c[*]} 
    2 3 4 5

    直接通过 ${数组名[@或*]:起始位置:长度} 切片原先数组,返回是字符串,中间用“空格”分开,因此如果加上”()”,将得到切片数组,上面例子:c 就是一个新数据。

    3.2 替换:

    [chengmo@centos5 ~]$ a=(1 2 3 4 5)    
    [chengmo@centos5 ~]$ echo ${a[@]/3/100}
    1 2 100 4 5
    [chengmo@centos5 ~]$ echo ${a[@]}
    1 2 3 4 5
    [chengmo@centos5 ~]$ a=(${a[@]/3/100}) 
    [chengmo@centos5 ~]$ echo ${a[@]}     
    1 2 100 4 5

    调用方法是:${数组名[@或*]/查找字符/替换字符} 该操作不会改变原先数组内容,如果需要修改,可以看上面例子,重新定义数据。

  • 相关阅读:
    Day1-CSS-下拉菜单
    scau 1138 代码等式
    SCAU-1076 K尾相等数
    勾股数专题-SCAU-1079 三角形-18203 神奇的勾股数(原创)
    SCAU-1144 数星星-HDU-1166-树状数组的应用
    NodeJs Fs模块
    Node核心模块
    flutter环境配置
    纯CSS制作图形效果
    CSS3选择器
  • 原文地址:https://www.cnblogs.com/zhangqingsh/p/2997608.html
Copyright © 2020-2023  润新知