目录
一、函数
1、函数是什么?
2、函数的格式
3、函数的调用方法
①脚本:查看当前操作系统
②脚本二:函数备份yum线上源,创建yum本地源和清理缓存安装httpd
4、函数的返回值
5、函数传参
6、函数变量的作用范围
1、实例:shell脚本中变量默认全局有效
2、例子2:将变量限定在函数内部使用local命令
7、函数的递归
①举例:阶乘
二、数组
1、数组是什么?
2、数组的语法格式
3、数组的数据类型
4、获取数组的长度
5、获取数组的数据表列
6、获取数组下标对应的值
7、数组的常用操作
①数组的遍历
②数组切片
③数组替换
④数组删除和指定下标的值删除
⑤数组追加元素
方法一:直接使用下标进行元素的追加
方法二:将数组的长度作为下标进行追加元素
方法三:使用+=进行追加
⑥declare -a :查看所有组
一、函数
1、函数是什么?
函数定义:封装的可重复利用的具有特定功能的代码
函数就是可以在shell脚本当中做出一个类似自定义执行的命令的东西,最大的功能就是简化我们很多的代码。
将命令序列按照格式书写在一起
可方便重复使用命令序列
2、函数的格式
方法一:
[function] 函数名 (){
命令序列
[return x] #使用return或者exit可以显式的结束函数
}
方法二:
函数名(){
命令序列
}
注意事项:①直接写函数中调用函数 直接写函数名
②同名函数 后一个生效
③调用函数一定要先定义
④只要先定义调用的 其他函数定义顺序无关
3、函数的调用方法
①脚本:查看当前操作系统
#定义函数
#!/bin/bash
os (){
if grep -i -q "CentOS Linux 7 " /etc/os-release
then
echo "此操作系统是centos 7"
elif grep -i -q "CentOS Linux 6 " /etc/os-release
then
echo "此操作系统是centos 6"
elif grep -i -q "CentOS Linux 8 " /etc/os-release
then
echo "此操作系统是centos 8"
fi
}
#调用函数
os
②脚本二:函数备份yum线上源,创建yum本地源和清理缓存安装httpd
#!/bin/bash
backups(){
cd /etc/yum.repos.d
mkdir repo.bak
mv *.repo repo.bak
mount /dev/sr0 /mnt >/dev/null
}
configuration(){
echo -e '[local]\nname=local\nbaseurl=file:///mnt\nenable=1\ngpgcheck=0' >/etc/yum.repos.d/local.repo
}
clean(){
yum clean all
yum makecache
yum install -y httpd > /dev/null
}
backups
configuration
clean
4、函数的返回值
return表示退出函数并返回一个退出值,脚本中可以使用$?变量显示该值
使用原则:
函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码
退出状态码必须是0-255,超出时值将为除以256取余数
解决大于255的方法
5、函数传参
在Shell中,调用函数时可以向其传递参数。在函数体内部,通过$n的形式来获取参数的值
例如,$1表示第一个参数,$2表示第二个参数...即使用位置参数来实现参数传递
示例脚本:
#!/bin/bash
sum () {
echo "第一个位置参数:" $1
echo "第二个位置参数:" $2
let n=$1+$2
echo $n
}
sum $2 $1
6、函数变量的作用范围
①函数在shell脚本中仅在当前shell环境中有效
②shell脚本中变量默认全局有效
③将变量限定在函数内部使用local命令
1、实例:shell脚本中变量默认全局有效
输出结果为 函数中定义的值
#!/bin/bash
fun(){
i=10
}
i=20
fun
echo $i
2、例子2:将变量限定在函数内部使用local命令
将变量限定在函数内部使用,输出函数体内变量i的值为10
#!/bin/bash
fun(){
local i=10
echo $i
}
i=20
fun
echo $i
7、函数的递归
函数调用自己本身的函数
①举例:阶乘
二、数组
1、数组是什么?
②数组中可以存放多个值。bash shell 只支持一维数组(不支持多维数组),初始化时不需要定义数组大小
②与大部分编程语言类似,数组元素的下标由0开始
③shell数组用括号来表示,元素用“空格”符号分开
④在shell语句中,使用遍历数组的时候,数组格式要写成${arr[@]}或${arr[*]}
2、数组的语法格式
格式一:
数组名=(value1 value2 ... valuen)
arr_number=(1 2 3 4 5 6 7 8 9)
格式二:
数组名=([0]=value0 [1]=value0 [2]=value0 ...)
arr_number=([0]=1 [1]=2 [2]=3 [3]=4)
格式三:
列表名:“value1 value2 valueN ..."
数组名=($列表名)
list_number="1 2 3 4 5 6"
arr_number=($list_number)
格式四:
数组名[0]="value"
数组名[1]="value"
数组名[2]="value"
arr_number[0]=1
arr_number[1]=2
arr_number[2]=3
3、数组的数据类型
①数值类型
②字符类型
③使用“”(双引号) 或者‘’(单引号)定义
4、获取数组的长度
echo ${#数组名[*]}
echo ${#数组名[@]}
5、获取数组的数据表列
echo ${数组名[*]}
echo ${数组名[@]}
6、获取数组下标对应的值
数组名=(元素0 元素1 元素2 ……) 定义数组
echo ${数组名[索引值]} 输出数组索引值对应的元素,索引值为从0开始
7、数组的常用操作
①数组的遍历
#!/bin/bash
a=(1 2 3 4 5 6)
for i in ${a[@]}
do
echo $i
done
②数组切片
a=(0 1 2 3 4 5 6 7 8)
echo "输出整个数组: " ${a[@]}
echo "取出数组1到3: " ${a[@]:1:3}
echo "取出数组5到后面所有的元素: " ${a[@]:5:5}
③数组替换
#临时替换
echo ${a[@]/原替换位置/替换内容}
#重新赋值,可以永久修改
a=(${a[@]/原替换位置/替换内容})
④数组删除和指定下标的值删除
#删除整个数组
unset 数组名
#删除指定下标的值
unset 数组名[数组下标]
⑤数组追加元素
方法一:直接使用下标进行元素的追加
数组名[下标]=变量
方法二:将数组的长度作为下标进行追加元素
数组名[${数组名[@]}]=变量名
方法三:使用+=进行追加
数组名+=(变量1 变量2 ...)