zoukankan      html  css  js  c++  java
  • linux shell 数组建立及使用技巧

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

    linux shell在编程方面比windows 批处理强大太多,无论是在循环、运算以及数据类型方面都是不能比较的。 下面是在数组方面一些操作的总结。

    1、数组定义

    [hadoop@Master ~]$ a=(1 2 3 4 5)
    [hadoop@Master ~]$ echo $a
    1

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

    2、数组读取与赋值

    • 获取长度:

    [hadoop@Master ~]$ echo ${#a[@]}
    4

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

    • 读取:

    [hadoop@Master ~]$ echo ${a[0]}
    1
    [hadoop@Master ~]$ echo ${a[*]}
    1 2 3 4

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

    • 赋值:

    [hadoop@Master ~]$ a[1]=100
    [hadoop@Master ~]$ echo ${a[*]}
    1 100 3 4
    [hadoop@Master ~]$ a[3]=100
    [hadoop@Master ~]$ echo ${a[*]}
    1 100 3 100
    [hadoop@Master ~]$ a[4]=100
    [hadoop@Master ~]$ echo ${a[*]}
    1 100 3 100 100

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

    • 删除:

    [hadoop@Master ~]$ a=(1 2 3 4 5)
    [hadoop@Master ~]$ echo ${a[*]}
    1 2 3 4 5
    [hadoop@Master ~]$ unset a
    [hadoop@Master ~]$ echo ${a[*]}

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

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

    3、特殊使用

    • 分片:

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

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

    • 替换:

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

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

  • 相关阅读:
    【转】CNN卷积神经网络_ GoogLeNet 之 Inception(V1-V4)
    【转】Caffe的solver文件配置
    python 从filelist.txt中拷贝文件到另一文件夹中
    【转】fscanf 跳过空格,读取一行
    caffe配置NCCL
    caffe实现多任务学习
    mysql 2
    mysql 1
    mysql
    jQuery
  • 原文地址:https://www.cnblogs.com/zhangwuji/p/7692713.html
Copyright © 2011-2022 走看看