数组、字符串处理及变量

拍照是被动学习,记笔记才是主动学习!

QQ截图20180511132046

数组、字符串处理及变量

1、数组

变量:存储单个元素的内存空间

数组:存储多个匀速的连续的内存空间,相当于多个变量的集合

数组名和索引:编号从0开始的是数值索引;编号为自定义的为关联索引;bash的数组支持稀疏格式(索引不连续)

声明数组:declare  -a/-A  ARRAY_NAME   普通数组/关联数组(两者不可相互转换)

 

2、数组元素的赋值

一次只赋值一个元素

ARRAY_NAME[INDEX]=VALUE

weekdays[0]=”Sunday”

weekdays[4]=”Thursday”

一次赋值全部元素ARRAY_NAME=(“VAL1” “VAL2” “VAL3” …)

只赋值特定元素ARRAY_NAME=([0]=”VAL1″ [3]=”VAL2″ …)

交互式数组值对赋值read -a ARRAY

显示所有数组:declare -a

 

3、引用数组

引用数组元素: ${ARRAY_NAME[INDEX]}     注意:省略[INDEX]表示引用下标为0的元素

引用数组所有元素: ${ARRAY_NAME[*]}    ${ARRAY_NAME[@]}

数组的长度(数组中元素的个数): ${#ARRAY_NAME[*]}    ${#ARRAY_NAME[@]}

删除数组中的某元素:导致稀疏格式 unset ARRAY[INDEX]

删除整个数组: unset ARRAY

 

4、数组数据处理

引用数组中的元素:

数组切片:${ARRAY[@]:offset:number} ;offset: 要跳过的元素个数; number: 要取出的元素个数; 取偏移量之后的所有元素:${ARRAY[@]:offset}

向数组中追加元素: ARRAY[${#ARRAY[*]}]=value

关联数组: declare -A ARRAY_NAME; ARRAY_NAME=([idx_name1]=’val1′ [idx_name2]=’val2‘…)  注意:关联数组必须先声明再调用

示例1:生成10个随机数保存于数组中,并找出其最大值和最小值

#!/bin/bash

declare -i min max

declare -a nums

for ((i=0;i<10;i++));do

nums[$i]=$RANDOM

[ $i -eq 0 ] && min=${nums[$i]} && max=${nums[$i]}&& continue

[ ${nums[$i]} -gt $max ] && max=${nums[$i]}

[ ${nums[$i]} -lt $min ] && min=${nums[$i]}

done

echo “All numbers are ${nums[*]}”

echo Max is $max

echo Min is $min

示例2:编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件;统计出其下标为偶数的文件中的行数之和

#!/bin/bash

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)

fi

done

echo “Lines: $lines.”

 

5、字符串切片

${#var}:返回字符串变量var的长度

${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间(bash4.2后,允许为负值)

${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

${var: -length}:取字符串的最右侧几个字符。注意:冒号后必须有一空白字符

${var:offset:-length}:从最左侧跳过offset字符,一直向右取到距离最右侧lengh个字符之前的内容

${var: -length:-offset}:先从最右侧向左取到length个字符开始,再向右取到距离最右侧offset个字符之间的内容。注意:-length前空格

 

6、字符串处理

基于模式取子串

${var#*word}:其中word可以是指定的任意字符

功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符

${var##*word}:同上,贪婪模式,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容

示例: file=“var/log/messages”,${file#*/}: log/messages ,${file##*/}: messages

${var%word*}:其中word可以是指定的任意字符

功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符

file=”/var/log/messages”

${file%/*}: /var/log

${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符;

示例: url=http://www.magedu.com:80 ${url##*:} 80 ${url%%:*} http

查找替换:

${var/pattern/substr}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substr替换之

${var//pattern/substr}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substr替换之

${var/#pattern/substr}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substr替换之

${var/%pattern/substr}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substr替换之

查找并删除:

${var/pattern}:删除var所表示的字符串中第一次被pattern所匹配到的字符串

${var//pattern}:删除var所表示的字符串中所有被pattern所匹配到的字符串

${var/#pattern}:删除var所表示的字符串中所有以pattern为行首所匹配到的字符串

${var/%pattern}:删除var所表示的字符串中所有以pattern为行尾所匹配到的字符串

字符大小写转换

${var^^}:把var中的所有小写字母转换为大写

${var,,}:把var中的所有大写字母转换为小写

 

7、变量赋值

图片1

${var:-value} 或 ${var-value}:如果var为空或未设置,那么返回value;否则返回var的值

${var:+value}:如果var非空,则返回value,否则返回空值

${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则返回var的值

${var:?error_info}:如果var为空或未设置,那么在当前终端打印error_info;否则返回var的值

图片2

为脚本程序使用配置文件,实现变量赋值: (1) 定义文本文件,每行定义“name=value” ;(2) 在脚本中source此文件即可。

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/98121

发表评论

登录后才能评论

联系我们

400-080-6560

在线咨询:点击这里给我发消息

邮件:1823388528@qq.com

工作时间:周一至周五,9:30-18:30,节假日同时也值班