cremeb多商户打包代码的时候,总是重复的工作,就想着写了个脚本,记录一下sh脚本用到的一下方法:
点击了解[CRMEB多商户](http://github.crmeb.net/u/meng) 其他开源项目源码下 :[了解更多](http://github.crmeb.net/u/lanlan)
小姐姐二维码
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210415142307512.png)
1. `#!/bin/bash` 文件第一行,提示电脑后面的代码需要用 /bin/bash 来解读
2. `echo` 输出内容,
3. `param=$(cat ./test.txt)` 变量赋值,参数名\等号\值,三个之间不能有空格,如果需要得到某够命令获取的信息作为值,都可以用这种方式,变量=$(命令);
4. 变量赋值单引号与双引号的区别,单引号不会转义内容,双引号会转义内容;
5. 变量的使用 ` $param`或者` ${param}`即可使用;
6. 获取用户输入值
```shell
echo "请输入你想要输入的值"
read inputValue
echo $inputValue #这里打印出来的就是用户输入的值
param=$inputValue #这里将用户输入的值赋给了param
echo $param #这里打印出来的也是用户输入的值
```
![在这里插入图片描述](https://img-blog.csdnimg.cn/2021041909523820.png)
7. sh 下标传入参数 `sh ./test.sh a b `
```shell
#!/bin/bash
echo $0 # test 执行的文件名
echo $1 #a 第一个参数
echo $2 #b 第二个参数 可以继续写
echo $# #2 传递到脚本的参数个数
echo $* #a b 以一个单字符串显示所有向脚本传递的参数
echo $$ # 当前的进程号
echo $! #d 后台运行的最后一个进程号
..
```
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210419115417693.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl81MjY3MzQ0OA==,size_16,color_FFFFFF,t_70)
8. `getopts` sh脚本传参数方法,如:`test.sh -a 1`
创建脚本test.sh
```shell
#!/bin/bash
while getopts "a:w:p:n" arg; #这里设定了参数必须是-a;-w;-p;-n这几个参数名,后面的冒号表示必须传入参数
do
case $arg in
a ) #所有版本号统一
parms1="$OPTARG"
;;
w ) #前端版本号
parms2="$OPTARG"
;;
p ) #php版本号
parms3="$OPTARG"
;;
n ) #最新版本号
parms4=1
;;
? )
echo "未知参数: -a; -w ; -p ; -n "
exit
esac
done
```
例如执行`sh ./test.sh -a 1` 可以选择参数名-a 就必须传入参数 1,-n则可以不用参数;
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210419100618668.png)
9. 字符串的操作
```shell
param='abcd_';
param1="$param"'efgh' #拼接字符串,直接跟着写即可
echo $param1 #abcd_efgh
echo ${#param1} #计算字符串长度 输出 9
echo ${param1:1:4} #截取字符串 从1号下标开始到4号结束 输出 bcd_ 都知道下标从0开始的吧
echo ${param1#abcd_} #从左相右匹配截取剩下的字符串,注意必须从头开始算,也就是说不能写个d_开始匹配, 输出efgh
echo ${param1#*_} #从左相右匹配截取剩下的字符串*代表任意,类似 .* 输出efgh
echo ${param1%gh} #从右向左匹配截取剩下的字符串,注意必须从末尾开始算,也就是说不能写个_e开始匹配, 输出 abcd_ef
echo ${param1%_*} #从右向左匹配截取剩下的字符串*代表任意,类似 .* 输出abcd_ef
echo ${param1:0-4} #从右向左匹配2个,截取 输入 efgh
echo ${param1:0-4:2} #从右向左截取4个,然后在从这4个中,从左向右截取2个 输出 gh
```
10. 数组
```shell
array=(a b c d) #数组的定义
echo ${array[*]} 或 echo ${array[@]} #输出数组全部值 a b c d
echo ${array[0} # a 下标式输出
```
11. 数字的运算,必须用 “`”这个符号包起来,这不是单引号,是反引号
```shell
echo `expr 1 + 1 ` #加
echo `expr 2 - 1 ` #减
echo `expr 2 \* 2` #乘
echo `expr 4 / 2 ` #除
echo `expr 5 % 2 ` #取余数
let a=1+1
let b=2-1
echo $a $b # let 定义一个或多个表达式
```
12. `if`流程控制
```shell
if [ ] ;#条件,注意空格
then #执行
elif #条件
then #执行
else #否
fi #结束标签
! # 非 if [ $a !$b ]
-a #and 与 if [ $a -a $b ]
-o #or 或 if [ $a -o $b ]
&& # AND
|| # OR
数字的比较
-eq #检测两个数是否相等
-ne #检测两个数是否不相等
-gt #检测左边的数是否大于右边的
-lt #检测左边的数是否小于右边的
-ge #检测左边的数是否大于等于右边的
-le #检测左边的数是否小于等于右边的
字符串的比较
= 检测两个字符串是否相等
!= 检测两个字符串是否不相等
-z 检测字符串长度是否为0
-n 检测字符串长度是否不为0
$ 检测字符串是否为空
文件夹比较
-e 判断对象是否存在
-d 判断对象是否存在,并且为目录
-f 判断对象是否存在,并且为常规文件
-L 判断对象是否存在,并且为符号链接
-h 判断对象是否存在,并且为软链接
-s 判断对象是否存在,并且长度不为0
-r 判断对象是否存在,并且可读
-w 判断对象是否存在,并且可写
-x 判断对象是否存在,并且可执行
-O 判断对象是否存在,并且属于当前用户
-G 判断对象是否存在,并且属于当前用户组
-nt 判断file1是否比file2新 [ "/usr/test1.txt" -nt "/usr/test2.txt" ]
-ot 判断file1是否比file2旧 [ "/usr/test1.txt" -ot "/usr/test2.txt" ]
```
13. for 循环
```shell
param=(1 2 3 4 5 6 7 8)
for i in ${param[*]} # 这个in后面的要是输出的形式展示
do
echo $i # 1 2 3 4 5 6 7 8
done
```
14. while 循环
```shell
i=1
while(( $i<7 )) #当这个条件成功,则不在执行
do
echo $i
let "i++" # 1 2 3 4 5 6
done
```
15. `break` 跳出循环整个循环体都不在执行,`continue `跳过本次循环继续下一个循环,`exit` 结束脚本;
16. 函数方法
```shell
#定义函数
function name(){
return 1
}
name(){}
name 1 2 #函数调用,(1,2)是传入的参数
param=$? #获取函数renturn回来的值
echo $param #2 函数返回的值
```
##### 暂时就用到这些