SHELL脚本

shell脚本

运算符

1
2
3
4
5
6
# 他的功能是把第一个命令command 1执行的结果作为command2的输入传给command 2
command 1 | command 2
# 只有左边的命令成功执行,才能够执行右边的命令
command1 && command2
# 只有左边的命令执行失败,才能够执行右边的命令
command1 || command2

基本运算符

expr是一款表达式计算工具,注意,例如expr 2 + 2表达式和运算符之间要有空格

算数运算符

注意:条件表达式要放在方括号之间,并且要有空格,例如: [$a==$b] 是错误的,必须写成 [ $a == $b ]

sh脚本编写完成,执行之前需要chmod +x的意思就是给执行权限

1
2
[ROOT ~]$ chmod +x demo.sh
[ROOT ~]$ ./demo.sh

关系运算符

-eq 检测两个数是否相等

-ne 检测两个数是否不相等

-gt 检测左边的数是否大于右边的,如果是,则返回 true。(greater )

-lt 检测左边的数是否小于右边的,如果是,则返回 true。 (less)

-ge 检测左边的数是否大于等于右边的,如果是,则返回 true。

-le检测左边的数是否小于等于右边的,如果是,则返回 true。

需要注意的是-eq只适合数字之间的比较,如果比较的是文字,那么使用= 符号

布尔运算符

-o 或运算

-a 与运算

逻辑运算

&& 逻辑的AND

|| 逻辑的OR

字符串运算

-z 检测字符串长度是否为0,为0返回 true

-n 检测字符串长度是否为0,不为0返回 true

$ 检测字符串是否为空,不为空返回 true。

文件测试运算符

检测是否为对应的设备类型

-b file 检测文件是否是块设备文件,如果是,则返回 true。 [ -b $file ] 返回 false。
-c file 检测文件是否是字符设备文件,如果是,则返回 true。 [ -c $file ] 返回 false。
-d file 检测文件是否是目录,如果是,则返回 true。 [ -d $file ] 返回 false。
-f file 检测文件是否是普通文件(既不是目录,也不是设备文件),如果是,则返回 true。 [ -f $file ] 返回 true。
-g file 检测文件是否设置了 SGID 位,如果是,则返回 true。 [ -g $file ] 返回 false。
-k file 检测文件是否设置了粘着位(Sticky Bit),如果是,则返回 true。 [ -k $file ] 返回 false。
-p file 检测文件是否是有名管道,如果是,则返回 true。 [ -p $file ] 返回 false。
-u file 检测文件是否设置了 SUID 位,如果是,则返回 true。 [ -u $file ] 返回 false。
-r file 检测文件是否可读,如果是,则返回 true。 [ -r $file ] 返回 true。
-w file 检测文件是否可写,如果是,则返回 true。 [ -w $file ] 返回 true。
-x file 检测文件是否可执行,如果是,则返回 true。 [ -x $file ] 返回 true。
-s file 检测文件是否为空(文件大小是否大于0),不为空返回 true。 [ -s $file ] 返回 true。
-e file 检测文件(包括目录)是否存在,如果是,则返回 true。 [ -e $file ] 返回 true。

Shell流程

if ...else...fi

1
2
3
4
5
6
7
if condition
then
command1
command2
else
command3
fi

获取数组里的所有元素使用@

1
2
3
4
5
shuzu=(5 2 3 4)
for shuzi in ${shuzu[@]};
do
echo ${shuzi};
done

until 循环

一直执行命令直至条件为true时停止,和while相反

case 类似于java的switch

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
echo '输入 1 到 4 之间的数字:'
echo '你输入的数字为:'
read aNum
case $aNum in
1) echo '你选择了 1'
;;
2) echo '你选择了 2'
;;
3) echo '你选择了 3'
;;
4) echo '你选择了 4'
;;
*) echo '你没有输入 1 到 4 之间的数字'
;;
esac

2>&1的理解:将标准错误重定向到标准输出,通俗的讲就是将错误信息当做正常信息输出

command>/dev/null的理解:不显示任何信息,等同于将命令显示的信息放入垃圾箱内,且不能被恢复

wc命令 可以统计我们通过键盘输入的数据

nohup命令 不挂断的执行 nohup mv_data.sh >mv_data.log 2>&1 & 不间断的执行mv_data.sh脚本将正确和错误的信息都打印到mv_data.log中

set命令 查询所有变量,包括自定义和环境变量

env命令 查询所有环境变量

unset 删除变量(包括自定义和环境变量)

位置参数变量

$0 表示命令本身,其他$n 代表第n个参数,$*代表命令行中所有的参数,将他们看成一个整体,$@同样是所有参数,不过将每个都区别对待,$#代表所有参数的个数

预定义变量

$? 表示最后一次执行命令的返回状态。如果为0则上一条命令正确,非0则表示错误

$$ 表示当前进程号(PID)

$! 表示运行的最后一个进程号

tee -a>的区别

tee -a file 是将输出到标准输出的同时,追加到文件file中,如果文件不存在则创建,如果存在则在末尾追加内容

awk命令

赏个🍗吧
0%