sh脚本命令

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 函数返回的值

```

##### 暂时就用到这些

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容