数组是一种数据结构,可以在此上设计算法能更高效和方便的实现bash编程,本章对数组和字符串的切片做详细介绍。
数组是存储多个类似元素的连续的内存空间,和变量相比较,变量是存储单个元素的内存空间
declare -a ARRAY_NAME
declare -A ARRAY_NAME:关联数组
ARRAY_NAME[INDEX]=VALUE
例子:
weekdays[0]="Sunday"
weekdays[4]="Thursday"
ARRAY_NAME=("VAL1" "VAL2" "VAL3" ......)
ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)
关联数组赋值:ARRAY_NAME=([index_name]=‘val1‘ [index_name2]=‘val2‘ ......)
${ARRAY_NAME[INDEX]}
索引:编号从0开始,属于数值索引;注意:省略[INDEX]表示引用下标为0的元素
            注意:索引也可以使用自定义的格式,而不仅仅是数值格式。 bash4.0才支持,别的语言中叫key value类型
                 bash的数组支持稀疏格式;
引用所有元素:${ARRAY[@]} ${ARRAY[*]}
(数组中元素的个数): ${#ARRAY_NAME[*]} , ${#ARRAY_NAME[@]}
例子1:
        生成10个随机数,并找出其最大值和最小值:
        declare -a rand
        declare -i max=0
        for i in {0..9}; do
          rand[$i]=$RANDOM
           echo "${rand[$i]}"
           [ ${rand[$i]} -gt $max ] && max=${rand[$i]}
          done
          echo "Max: $max"
例子2:
         定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件,要统计其下标为偶数的文件中的行数之和
         declare -a files
         files=(/var/log/*.log)
         declare -i lines=0
         for i in $(seq 0 $[${#files[*]}-1]); do
                if [ $[$i%2] -eq 0 ]; then
                let lines+=$(wc -l ${files[$i]} | cut -d ‘ ‘ -f1)
                #= let lines+=`wc -l ${files[$i]} | cut -d ‘ ‘ -f1`
         fi
         done
         echo "lines:$lines"
    
${ARRAY[@]:offset:number} 切片
                   offset: 要跳过的元素个数
                   number:要取出的元素个数,取偏移量之后的所有元素:${ARRAY[@]:offset}
ARRAY[${#ARRAY[*]}]=
unset ARRAY[INDEX]
    ${var:offset:number}
    取字符串的最右侧的几个字符:${var: -length}
         注意:冒号后必须有一空白字符
        ${var#*word}:其中word可以是指定的任意字符:功能:自左而右,查找var变量所存储的字符串中,第一次出现的word,删除字符串开头至第一次出现word字符之间的所有字符
        ${var##*word}:同上,不过,删除的是字符串开头至最后一次由word指定的字符之间的所有字符(basename)
     file="/var/log/messages"
     ${file##*}: messages
        ${var%word*}:其中word可是是指定的任意字符:功能:自右而左,查找var变量所存储的字符串中,第一次出现的word,删除字符串最后一个字符向左至第一次出现word字符之间的所有字符
    file="/var/log/messages"
     echo ${file%/*}
        ${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符
示例:url=http://www.magedu.com:80
                ${url##:} : 80
                ${url%%:*} : http
        ${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替换之
        ${var//pattern/substi}:查找var所示的字符串,所有能被pattern所匹配到的字符串,以substi替换之
    user=$(head -1 /etc/passwd)
    echo ${user/root/ROOT}
        ${var/#pattern/substi}:查找var所示的字符串,行首被pattern所匹配到的字符串,以substi替换之
        ${var/%pattern/substi}:查找var所示的字符串,行尾被pattern所匹配到的字符串,以substi替换之
        ${var/pattern}:删除第一次被pattern匹配的字符串
        ${var//pattern}:删除所以被pattern匹配的字符串
        ${var/#pattern}:删除行首被pattern匹配的字符串
        ${var/%pattern}:删除行尾被pattern匹配的字符串
        ${var^^}:把var中的所有小写字符转换为大写
        ${var,,}:把var中的所有大写字符转换为小写
${var:-value}:如果var为空或未设置,那么返回value;否则返回var的值
        ${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则返回var的值
        ${var:+value}:如果var不空,返回value的值;
        ${var:?error_info}:如果var为空或未设置,那么返回error_info;否则,则返回var的值
        (1)定义文本文件,每行定义"name=value"
        (2)在脚本中source此文件即可
原文:https://www.cnblogs.com/liangjindong/p/9042648.html