数组
变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合。
数组名和索引
索引:编号从0开始,属于数值索引
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引, bash4.0版本之后开始支持。
bash的数组支持稀疏格式(索引不连续)
定义数组
声明数组:
declare -a ARRAY_NAME
declare -A ARRAY_NAME: 关联数组
数组元素的赋值:
(1) 一次只赋值一个元素;
ARRAY_NAME[INDEX]=VALUE
weekdays[0]="Sunday"
weekdays[4]="Thursday"
(2) 一次赋值全部元素:
ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)
(3) 只赋值特定元素:
ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)
(4) 交互式数组值对赋值
read -a ARRAY
引用数组
引用数组元素: ${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下标为0的元素
数组的长度(数组中元素的个数):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
示例:生成10个随机数保存于数组中,并找出其最大值和最小值 #!/bin/bash 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"
例:写一个脚本,定义一个数组,数组中的元素是/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."
数组数据处理
引用数组中的元素:
所有元素: ${ARRAY[@]}, ${ARRAY[*]}
数组切片: ${ARRAY[@]:offset:number}
offset: 要跳过的元素个数
number: 要取出的元素个数
取偏移量之后的所有元素
${ARRAY[@]:offset}
向数组中追加元素:
ARRAY[${#ARRAY[*]}]
删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]
关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]=('val1' [idx_name2]='val2‘…)
字符串处理
bash的字符串处理工具:
字符串切片:
${#var}:返回字符串变量var的长度
${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间
${var:offset:number}:返回字符串变量var中从第
offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分
${var: -lengh}:取字符串的最右侧几个字符:
注意:冒号后必须有一空白字符
基于模式取子串:
${var#*word}:其中word可以是指定的任意字符
功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符
${var##*word}:同上,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容
file="/var/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/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替换之 ${var//pattern/substi}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替换之 ${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替换之 ${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替换之 字符串处理 查找并删除: ${var/pattern}:查找var所表示的字符串中,删除第一次被pattern所匹配到的字符串 ${var//pattern}:所有 ${var/#pattern}:首行 ${var/%pattern}:行尾 字符大小写转换: ${var^^}:把var中的所有小写字母转换为大写 ${var,,}:把var中的所有大写字母转换为小写 变量赋值 ${var:-value}:如果var为空或未设置,那么返回value;否则,则返回var的值 ${var:+value}:如果var不空,则返回value ${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则,则返回var的值 ${var:?error_info}:如果var为空或未设置,那么返回error_info;否则,则返回var的值
高级变量用法-有类型变量
Shell变量一般是无类型的,但是bash Shell提供了declare和typeset两个命令用于指定变量的类型,两个命令是完全等价的
declare [选项] 变量名
-r 将变量设置为只读属性
-i 将变量定义为整型数
-a 将变量定义为数组
-f 显示此脚本前定义过的所有函数名及其内容
-F 仅显示此脚本前定义过的所有函数名
-x 将变量声明为环境变量
-l 将变量值转为小写字母
-u 将变量值转为大写字母
间接变量引用
如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值就称为间接变量引用
variable1=variable2
variable2=value
variable1的值是variable2,而variable2又是变量名,
variable2的值为value,间接变量引用是指通过variable1获得变量值value的行为
间接变量引用
bash Shell提供了两种格式实现间接变量引用
eval tempvar=\$$variable1
tempvar=${!variable1}
安装复制文件
install命令:
install [OPTION]… [-T] SOURCE DEST 单文件
install [OPTION]… SOURCE… DIRECTORY
install [OPTION]… -t DIRECTORY SOURCE…
install [OPTION]… -d DIRECTORY…创建空目录
选项:
-m MODE,默认755
-o OWNER
作业:生成10个随机数,采用冒泡算法进行升序或降序排序
[root@localhost ~]# cat maopao.sh #!/bin/bash declare -a arr for i in "$@"; do arr[${#arr[*]}]=$i done echo "${arr[*]}" for j in `seq 0 $[${#arr[*]}-2]`; do for k in `seq 0 $[$[${#arr[*]}-2]-$j]`; do if [[ ${arr[$k]} -gt ${arr[$[$k+1]]} ]];then num=${arr[$[$k+1]]} arr[$[$k+1]]=${arr[$k]} arr[$k]=$num fi done done echo "${arr[*]}" [root@localhost ~]# bash maopao.sh 1 2 3 5 48 21 1 54 12 0 12 0 12 0 1 2 3 5 48 21 1 54 12 0 12 0 12 0 0 0 0 1 1 2 3 5 12 12 12 21 48 54
作业2:
删除内核包,并修复
1、查看内核包:
rpm -q kernrl
2、删除内核包,忽略依赖性
rpm -e kernel –nodeps
3、重启发现启动不了
4、虚拟机设置光盘连接
5、重启按esc进入bios选择光盘启动
6、进入救援模式
7、修复内核不需要网络连接,选择no
8、选择continue
9、提示进入root模式使用该命令
10、提示原系统挂载在/mnt/sysimage下
11、选择打开一个shell
12、df查看分区情况
13、挂载光盘至/tmp/ cd到光盘目录,使用rpm安装内核包,指定原系统在/mnt/sysimage
14、安装完成后reboot重启,耐心等待启动,这里可能有点慢
15、启动成功
原创文章,作者:M20-1--孔祥文,如若转载,请注明出处:http://www.178linux.com/39940
评论列表(1条)
文章对数组的知识总结的较为全面,如果能对切片工具的使用做一个更为详细的总结介绍,会让读者能清晰的明白数组的用法。