脚本内容补充
数组
变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合。
数组名和索引
索引:编号从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
(5) 关联数组的赋值
必须先定义,然后赋值
declare -A shu_zu
shu_zu=([a]="sadas" [b]=22 [w2]=w [2]=2)
[root@qzx ~]# declare -A shu_zu
[root@qzx ~]# shu_zu=([2]=4 [a]="ni shi shui " [b]=22 [w1w]="ww s")[root@qzx ~]# echo ${shu_zu[w1w]}
ww s
[root@qzx ~]# echo ${shu_zu[b]}
22
[root@qzx ~]# echo ${shu_zu[*]}
ww s ni shi shui 22 4
引用数组
引用数组元素:${ARRAY_NAME[0]}
注意:省略[0]表示引用下标为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."
作业练习:
1.输入若干个数值存入数组中,采用冒泡算法进行升序或降序排序
#!/bin/bash #qzx # declare -a paixu print() { echo ${paixu[*]} } for ((i=0;i<10;i++)) do let paixu[$i]=$RANDOM%100 done echo "刚赋值的" print echo "===============================================" for ((i=0;i<9;i++)) do #let c=9-i for((j=0;j<9-i;j++)) do # if [[ ${paixu[$j]} -lt ${paixu[$j+1]} ]] then a=${paixu[$j]} paixu[$j]=${paixu[$j+1]} paixu[$j+1]=$a fi done done echo "倒排序的" print echo "==============================================" for ((i=0;i<5;i++)) do a=${paixu[$i]} paixu[$i]=${paixu[9-$i]} paixu[9-$i]=$a done echo "正序排列" print
数组数据处理
引用数组中的元素:
-
所有元素:${ARRAY[@]}, ${ARRAY[*]}
-
数组切片:${ARRAY[@]number}
-
offset: 要跳过的元素个数
-
number: 要取出的元素个数
[root@qzx ~]# read -a qiuzx 2 34 5 77 44 83 2 [root@qzx ~]# echo ${qiuzx[@]:2:4} 5 77 44 83
取偏移量之后的所有元素
${ARRAY[@]:offset}
向数组中追加元素:
ARRAY[${#ARRAY[*]}]=“在原有数据上追加一个的值”
删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]
关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)
字符串处理
字符串切片:这里的offset,number,-lengh均为数字
-
${#var}:返回字符串变量var的长度
-
${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到 ${#var}-1 之间(bash4.2后,充许为负值)
-
${var : offset : number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分
-
${var: -lengh}:取字符串的最右侧几个字符:
注意:冒号后必须有一空白字符 -
${var : offset : -lengh}:取字符串从offset之后的(不包括offset这个字符)到从右侧数第lengh个字符之前的字符
[root@qzx ~]# a=00123456789 [root@qzx ~]# echo ${#a} 11 [root@qzx ~]# echo ${a:3: -4} 2345 [root@qzx ~]# echo ${a:3} 23456789 [root@qzx ~]# echo ${a:3:4} 2345
基于模式取子串:
-
${var#*word}:其中word可以是指定的任意字符
功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符 -
${var##*word}:同上,不同的是,删除的是字符串开
头至最后一次由word指定的字符之间的所有内容file="/var/log/messages"
${file##*/}: messages[root@qzx ~]# echo ${a#*0}
0123456789
[root@qzx ~]# echo ${a##*0}
123456789 -
${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}:行尾
[root@qzx ~]# a=000111222111222000111222000222 [root@qzx ~]# echo ${a/000} 111222111222000111222000222 [root@qzx ~]# echo ${a//000} 111222111222111222222 [root@qzx ~]# echo ${a/%222} 000111222111222000111222000 [root@qzx ~]# echo ${a/#000} 111222111222000111222000222
字符大小写转换:
-
${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}
示例:
[root@server ~]# N=NAME [root@server ~]# NAME=wangxiaochun [root@server ~]# N1=${!N} [root@server ~]# echo $N1 wangxiaochun [root@server ~]# eval N2=\$$A [root@server ~]# echo $2 wangxiaochun
这种是间接中的变量引用,是动态引用的!
创建临时文件
mktemp命令:创建的临时文件可避免冲突
语法:mktemp [OPTION]… [TEMPLATE]
TEMPLATE: filename.XXX
X至少要出现三个
选项:
-d: 创建临时目录
–tmpdir=/DIR:指明临时文件所存放的目录位置
实例:
#mktemp --tmpdir=/testdir test.XXXXXXmktemp
安装复制文件
install命令:
install [OPTION]… [-T] SOURCE DEST 单文件
install [OPTION]… SOURCE… DIRECTORY
install [OPTION]… -t DIRECTORY SOURCE…
install [OPTION]… -d DIRECTORY…创建空目录(支持递归创建)
在前两种格式中,会将<来源>复制至<目的地>或将多个<来源>文件复制至已存在的<目录>,同时设定权限模式及所有者/所属组。在第三种格式中,会创建所有指定的目录及它们的主目录。
选项:
-m MODE,自行设定权限模式 (像chmod),而不是rwxr-xr-x,默认755
-o OWNER
-g GROUP
bash如何展开命令行
优先级从高到低
-
把命令行分成单个命令词
-
展开别名
-
展开大括号种的声明({})
-
展开波浪符声明(~)
-
命令替换$() 和 “)
-
再次把命令行分成命令词
-
展开文件通配(*、?、[abc]等等)
-
准备I/0重导向(<、>)
-
运行命令
防止扩展
反斜线(\)会使随后的字符按原意解释
$ echo Your cost: \$5.00
Your cost: $5.00
加引号来防止扩展
• 单引号(’)防止所有扩展
• 双引号(”)也防止所有扩展,但是以下情况例外:
-
$(美元符号) - 变量扩展
-
`(反引号) - 命令替换
-
\(反斜线) - 禁止单个字符扩展
-
!(叹号) - 历史命令替换
bash的配置文件
按生效范围划分,存在两类:
全局配置:
/etc/profile
/etc/profile.d/*.sh
/etc/bashrc
个人配置:
~/.bash_profile
~/.bashrc
shell登录两种方式
交互式登录:
(1)直接通过终端输入账号密码登录;
(2)使用“su – UserName” 切换的用户
执行顺序:
/etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc
非交互式登录:
(1)su UserName
(2)图形界面下打开的终端
(3)执行脚本
执行顺序:
~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh
Profile类
profile类:为交互式登录的shell提供配置
-
全局:/etc/profile, /etc/profile.d/*.sh
-
个人:~/.bash_profile
功用:
(1) 用于定义环境变量
(2) 运行命令或脚本
Bashrc类
bashrc类:为非交互式和交互式登录的shell提供配置
-
全局:/etc/bashrc
-
个人:~/.bashrc
功用:
(1) 定义命令别名和函数
(2) 定义本地变量
修改profile和bashrc文件后需生效方法
两种方法:
1重新启动shell进程
2 . 或source
例:
. ~/.bashrc
Bash 退出任务
保存在~/.bash_logout文件中(用户)
在退出登录shell时运行
用于
• 创建自动备份
• 清除临时文件
原创文章,作者:qzx,如若转载,请注明出处:http://www.178linux.com/39671