数组
变量:存储单个元素的内存空间
v 数组:存储多个元素的连续的内存空间,相当于多个变量的集合。
v 数组名和索引
索引:编号从0开始,属于数值索引。
元素数量为n-1个
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引, bash4.0版本之后开始支持。
bash的数组支持稀疏格式(索引不连续)
定义数组
v 声明数组:
declare -a ARRAY_NAME 可以不用定义
declare -A ARRAY_NAME: 关联数组 必须定义
v 数组元素的赋值:
(1) 一次只赋值一个元素;
ARRAY_NAME[INDEX]=VALUE
(2) 一次赋值全部元素:
ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)
(3) 只赋值特定元素:
ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)
(4) 交互式数组值对赋值
read -a ARRAY
引用数组
v 引用数组元素: ${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下标为0的元素
v 数组的长度(数组中元素的个数):
${#ARRAY_NAME[*]} 或 ${#ARRAY_NAME[@]}
数组数据处理
v 引用数组中的元素:
所有元素: ${ARRAY[@]}, ${ARRAY[*]}
数组切片: ${ARRAY[@]:offset:number}
offset: 要跳过的元素个数 number: 要取出的元素个数
向数组中追加元素:
ARRAY[${#ARRAY[*]}] 从最后一个索引开始追加
v 删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]
删除了编号为[2]的数据,剩下的编号为【0】【1】【3】【4】【5】
v 关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)
字符串处理
v bash的字符串处理工具:
v 字符串切片:
${#var}:返回字符串变量var的长度
${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间(bash4.2后,充许为负值)
${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分
${var: -lengh}:取字符串的最右侧几个字符:
注意:冒号后必须有一空白字符
从右侧开始,取3个字符
字符串处理
v 基于模式取子串:
${var#*word}:其中word可以是指定的任意字符
功能:删除从左开始第一次匹配到的adm之前的内容,包括adm。
${var##*word}:
功能:删除从左面开始最后一次匹配到的adm之前的内容,包括adm。
字符串处理
v ${var%word*}:其中word可以是指定的任意字符;
功能:删除从右边开始第一次匹配到的adm之后的内容,包括adm。
v ${var%%word*}:删除从右边开始最后一次匹配到的adm之后的内容,包括adm。
字符串处理
v 查找替换:
${usb/adm/name}:将从左往右第一次匹配到的adm替换成name
${usb//adm/name}:将字符串中所有匹配到的adm替换成name
${usb/#:/y}:将行首被匹配到的字符串 :替换成 y。
${usb/%nologin/yes}:将行尾被nologin匹配到的字符替换成yes。
字符串处理
v 查找并删除:
v 字符大小写转换:
${usb^^}:把var中的所有小写字母转换为大写
${usb,,}:把var中的所有大写字母转换为小写
变量赋值
v ${var:-value}:如果var为空或未设置,那么返回value;否则,则返回var的值
v ${var:+value}:如果var不空,则返回value
v ${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则,则返回var的值
v
原创文章,作者:zzd,如若转载,请注明出处:http://www.178linux.com/39353
评论列表(1条)
文章对数组定义和调用等知识点整理的1很详细,如果嫩能够对于数组的实际应用实例有些详细的介绍,就更好了哦