数组
变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合
数组名:整个数组只有一个名字
数组索引:编号从0开始,属于数值索引
数组名[索引],
${ARRAY_NAME[INDEX]}
要注意的是bash-4以及之后的版本支持自定义索引格式,而不仅仅是0,1,2,3...数字格式
此类数组称之为”关联数组“
声明数组:
declare -a NAME :声明索引数组 declare -A NAME :声明关联数组 关联数组必须先声明后使用
数组中元素的赋值方式:
(1)一次只赋值一个元素
ARRAY_NAME[INDEX]=VALUE
[root@localhost fun]# tianshi[0]="datianshi"
[root@localhost fun]# tianshi[1]="xiaotianshi"
[root@localhost fun]# tianshi[2]="heitianshi"
(2)一次赋值全部元素
ARRAY_NAME=(“VAL1“ ”VAL2“ ”VAL3“...)
(1) [root@localhost fun]# tianshi=("datianshi" "xiaotianshi" "heitianshi")
(2)[root@localhost fun]# file=(/root/*)
(3) [root@localhost fun]# file=(`ls /root/`)
(3)只赋值特定元素
ARRAY_NAME=([0]="val1" [3]="val4"...)
[root@localhost fun]# tianshi=([0]="datianshi" [2]="heitianshi")
注意:bash支持稀疏格式的数组
(4)read -a ARRAY_NAME
[root@localhost fun]# read -a tianshi
datianshi heitianshi xiaotianshi
[root@localhost fun]# echo ${tianshi[*]}
datianshi heitianshi xiaotianshi
数组引用
引用数组中的元素:
${ARRAY_NAME[INDEx]}
注意:引用时,只给数组名,表示引用下标为0的元素。
${ARRAY_NAME[*]}:引用数组中的所有元素
${ARRAY_NAME[@]}:引用数组中的所有元素
数组的长度(数组中元素的个数):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
[root@localhost ~]# haochide[0]=baozi
[root@localhost ~]# haochide[1]=hongshaorou
[root@localhost ~]# haochide[2]=gongbaojiding
[root@localhost ~]# haochide[3]=jiangzhouzi
[root@localhost ~]# echo ${#haochide[@]}
4
[root@localhost ~]# echo ${#haochide[*]}
4
数组元素切片:
${ARRAY_NAME[@]:offset:number}
offset:要跳过的元素个数
number:要取出的元素个数
省略number的话是表示偏移量之后的所有元素
[root@localhost ~]# echo ${haochide[@]:1:2}
hongshaorou gongbaojiding
[root@localhost ~]# echo ${haochide[@]:1}
hongshaorou gongbaojiding jiangzhouzi
向非稀疏数组中追加元素:
ARRAY_NAME[${#ARRAY_NAME[*]}]=VALUE
删除数组中的元素:
unset ARRAY[INDEx]
[root@localhost ~]# unset haochide[3]
[root@localhost ~]# echo ${haochide[3]}
[root@localhost ~]# echo ${haochide[2]}
gongbaojiding
[root@localhost ~]#
关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([index_name1]="value1" [index_name2]="value2"...)
bash的内置字符串处理工具:
${#var}:返回字符串变量var的长度
[root@localhost ~]# echo ${var[*]}
abcdefghijklmnopqrstuvwxyz
[root@localhost ~]# echo ${#var}
26
字符串切片:
${var:offset:number}
取字符串的子串
[root@localhost ~]# echo ${var:3:5}
defgh
取字符的最右侧的几个字符:${var: -length}::冒号后面跟一个空格
[root@localhost ~]# echo ${var: -5}
vwxyz
两个结合使用的话就是跳过offset所包括的字符,到去掉-length的字符
[root@localhost ~]# echo ${var:5: -5}
fghijklmnopqrstu
基于模式取字符串:
${var#*word}:其中Word是指定的分隔符:
功能:自左而右,查找var变量所存储的字符串中,第一次出现的Word分隔符,删除字符串开头至此分隔符之间的所有字符;
[root@localhost ~]# echo ${var#*h}
ijklmnopqrstuvwxyz
${var##*word}:其中Word是指定的分隔符:
功能:自左而右,查找var变量所存储的字符串中,最后一次出现的Word分隔符,删除字符串开头至此分隔符之间的所有字符;
[root@localhost ~]# echo $var
abcdefgfggggggfadvk
[root@localhost ~]# echo ${var##*f}
advk
可以用这个方法取基名:
[root@localhost ~]# file="/etc/init.d/functions"
[root@localhost ~]# echo ${file##*/}
functions
${var%word*}:其中Word是指定的分隔符:
功能:自右而左,查找var变量所存储的字符串中,第一次出现的Word分隔符,删除字符串尾部至此分隔符之间的所有字符;
${var%word*}:其中Word是指定的分隔符:
功能:自右而左,查找var变量所存储的字符串中,最后一次出现的Word分隔符,删除字符串尾部至此分隔符之间的所有字符;
查找替换:
${var/PATTERN/SUBSTI}:查找var所表示的字符串中,第一次被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
[root@localhost ~]# echo $mantou
maozidacongyoumodacongdoubanjiangdacong
[root@localhost ~]# echo ${mantou/dacong/yangcong}
maoziyangcongyoumodacongdoubanjiangdacong
${var//PATTERN/SUBSTI}:查找var所表示的字符串中,所有被PATTERN所匹配到的字符串,将其全部替换为SUBSTI所表示的字符串;
[root@localhost ~]# echo $mantou
maozidacongyoumodacongdoubanjiangdacong
[root@localhost ~]# echo ${mantou//dacong/yangcong}
maoziyangcongyoumoyangcongdoubanjiangyangcong
${var/#PATTERN/SUBSTI}:查找var所表示的字符串中,行首被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
[root@localhost ~]# echo ${mantou/#maozi/baozi}
baozidacongyoumodacongdoubanjiangdacong
${var/%PATTERN/SUBSTI}:查找var所表示的字符串中,行尾被PATTERN所匹配到的字符串,将其替换为SUBSTI所表示的字符串;
[root@localhost ~]# echo ${mantou/%dacong/dasuan}
maozidacongyoumodacongdoubanjiangdasuan
注意:PATTERN中使用glob风格的通配符
[root@localhost ~]# echo ${mantou/maozi*youmo/dasuan}
dasuandacongdoubanjiangdacong
查找删除:
${var/PATTERN}::以PATTERN为模式查找var字符串中第一次匹配到的字符,并删除;
${var//PATTERN}:以PATTERN为模式查找var字符串中所有匹配到的字符,并删除;
${var/#PATTERN}
${var/%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值;
高级变量用法-有类型变量
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}
示例:
[root@localhost tmp]# v1=v2
[root@localhost tmp]# v2=nihaoa
[root@localhost tmp]# eval v3=\$$v1
[root@localhost tmp]# echo $v3
nihaoa
[root@localhost tmp]# echo ${!v1}
nihaoa
eval 命令
eval 命令将会首先扫描命令行中所有的变量然后进行所有变量的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。 示例: [root@localhost tmp]# a=whoami [root@localhost tmp]# echo $a whoami [root@localhost tmp]# `echo $a` root [root@localhost tmp]# eval $a root
创建临时文件
mktemp命令: 创建的临时文件可避免冲突 mktemp [OPTION]... [TEMPLATE] TEMPLATE: filename.XXX X 至少要出现三个 OPTION: : -d: 创建临时目录 -p DIR或--tmpdir=DIR:指明临时文件所存放目录位置 示 例 : #mktemp /tmp/test.XXX #tmpdir=`mktemp –d /tmp/testdir.XXX` #mktemp --tmpdir=/testdir test.XXXXXX
安装复制文件
install 命令: install [OPTION]... [-T] SOURCE DEST 单文件 install [OPTION]... SOURCE... DIRECTORY install [OPTION]... -t DIRECTORY SOURCE... install [OPTION]... -d DIRECTORY...创建空目录 选项: -m MODE ,默认755 -o OWNER -g GROUP
bash 如何展开命令行
把命令行分成单个命令词
展开别名
展开大括号种的声明({}) )
展开波浪符声明(~) )
命令替换$() 和 ``) )
再次把命令行分成命令词
展开文件通配(* 、? 、[abc] 等等)
准备I/0 重导向(< 、>) )
运行命令
反斜线(\ )会使随后的字符按原意解释
$ echo Your cost: \$5.00
Your cost: $5.00加引号来防止扩展
• 单引号(’ )防止所有扩展
• 双引号(”)也防止所有扩展,但是以下情况例外:
$ (美元符号) - 变量扩展
` (反引号) - 命令替换
\ (反斜线) - 禁止单个字符扩展
! (叹号) - 历史命令替换
作业:
输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序


运行后结果是:

原创文章,作者:dxkboke,如若转载,请注明出处:http://www.178linux.com/39703

