当前位置: 首页 > 工具软件 > lshell > 使用案例 >

linux数组切片,Lshell脚本编程进阶之数组,字符串切片

司空俊悟
2023-12-01

(一)数组定义

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

数组名和索引

索引:编号从0 开始,属于数值索引

注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引, ,bash4.0版本之后开始支持

bash 的数组支持稀疏格式(索引不连续)

声明数组:

declare -a ARRAY_NAME

declare -A ARRAY_NAME: 关联数组

注意:两者不可相互转换

(1)数组赋值

一次只赋值一个元素;

ARRAY_NAME[INDEX]=VALUE

weekdays[0]="Sunday"

weekdays[4]="Thursday"

(一次赋值全部元素:

ARRAY_NAME=("VAL1" "VAL2" "VAL3" ...)

只赋值特定元素:

ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)

交互式数组值对赋值

read -a ARRAY

(2)引用数组

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

数组的长度( 数组中元素的个数):

${#ARRAY_NAME[*]}

${#ARRAY_NAME[@]}

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

#!/bin/bash

declare -a rand

declare -i max=0

declare –i min=32767

for i in {0..9}; do

rand[$i]=$RANDOM

echo ${rand[$i]}

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

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

done

echo "Max: $max Min:$min"

编写脚本,定义一个数组,数组中的元素是/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

echo "Lines: $lines."

(3)数组数据处理

引用数组中的元素:

所有元素:${ARRAY[@]}, ${ARRAY[*]}

数组切片:${ARRAY[@]:offset:number}

offset: 要跳过的元素个数

number: 要取出的元素个数

取偏移量之后的所有元素

${ARRAY[@]:offset}

向数组中追加元素:

ARRAY[${#ARRAY[*]}]

删除数组中的某元素:导致稀疏格式

unset ARRAY[INDEX]

删除整个数组:unset ARRAY

关联数组:

declare -A ARRAY_NAME 注意:必须先声明,再调用

ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘...)

(一)字符串切片

(1)字符串处理切片

${#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个字符之间的内容

(2)字符串处理

基于模式取子串

${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

(2)字符串查找替换

${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^^}:把var 中的所有小写字母转换为大写

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

变量赋值

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

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

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

为脚本程序使用配置文件, 实现变量赋值

(1) 定义文本文件,每行定义“name=value”

(2) 在脚本中source此文件即可

 类似资料: