shell命令中的if

前端之家收集整理的这篇文章主要介绍了shell命令中的if前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

IF条件判断语法

基本语法:@H_301_5@ if [ command ]; then@H_301_5@ 符合该条件执行的语句@H_301_5@ fi@H_301_5@ 扩展语法:@H_301_5@ if [ command ];then@H_301_5@ 符合该条件执行的语句@H_301_5@ elif [ command ];then@H_301_5@ 符合该条件执行的语句@H_301_5@ else@H_301_5@ 符合该条件执行的语句@H_301_5@ fi@H_301_5@ 语法说明:@H_301_5@ bash shell会按顺序执行if语句,如果command执行后且它的返回状态是0,则会执行符合该条件执行的语句,否则后面的命令不执行,跳到下一条命令。@H_301_5@ 当有多个嵌套时,只有第一个返回0退出状态的命令会导致符合该条件执行的语句部分被执行,如果所有的语句的执行状态都不为0,则执行else中语句。@H_301_5@ 返回状态:最后一个命令的退出状态,或者当没有条件是真的话为0。

注意:

1、[ ]表示条件测试。注意这里的空格很重要。要注意在'['后面和']'前面都必须要有空格@H_301_5@ 2、在shell中,then和fi是分开的语句。如果要在同一行里面输入,则需要用分号将他们隔开。@H_301_5@ 3、注意if判断中对于变量的处理,需要加引号,以免一些不必要的错误。没有加双引号会在一些含空格等的字符串变量判断的时候产生错误。比如[ -n "$var" ]如果var为空会出错@H_301_5@ 4、判断是不支持浮点值的@H_301_5@ 5、如果只单独使用>或者<号,系统会认为是输出或者输入重定向,虽然结果显示正确,但是其实是错误的,因此要对这些符号进行转意@H_301_5@ 6、在默认中,运行if语句中的命令所产生的错误信息仍然出现在脚本的输出结果中@H_301_5@ 7、使用-z或者-n来检查长度的时候,没有定义的变量也为0@H_301_5@ 8、空变量和没有初始化的变量可能会对shell脚本测试产生灾难性的影响,因此在不确定变量的内容的时候,在测试号前使用-n或者-z测试一下@H_301_5@ 9、? 变量包含了之前执行命令的退出状态(最近完成的前台进程)(可以用于检测退出状态)

10、比较两个字符串是否相等的办法是:if [ "$test"x = "test"x ]; then。使用单个等号;注意到等号两边各有一个空格:这是unix shell的要求;注意到"$test"x最后的x,这是特意安排的,因为当$test为空的时候,上面的表达式就变成了x = testx,显然是不相等的。而如果没有这个x,表达式就会报错:[: =: unary operator expected

使用场景

文件/目录判断:@H_301_5@ [ -a FILE ] 如果 FILE 存在则为真。@H_301_5@ [ -b FILE ] 如果 FILE 存在且是一个块文件则返回为真。@H_301_5@ [ -c FILE ] 如果 FILE 存在且是一个字符文件则返回为真。@H_301_5@ [ -d FILE ] 如果 FILE 存在且是一个目录则返回为真。@H_301_5@ [ -e FILE ] 如果 指定的文件或目录存在时返回为真。@H_301_5@ [ -f FILE ] 如果 FILE 存在且是一个普通文件则返回为真。@H_301_5@ [ -g FILE ] 如果 FILE 存在且设置了SGID则返回为真。@H_301_5@ [ -h FILE ] 如果 FILE 存在且是一个符号符号链接文件则返回为真。(该选项在一些老系统上无效)@H_301_5@ [ -k FILE ] 如果 FILE 存在且已经设置了冒险位则返回为真。@H_301_5@ [ -p FILE ] 如果 FILE 存并且是命令管道时返回为真。@H_301_5@ [ -r FILE ] 如果 FILE 存在且是可读的则返回为真。@H_301_5@ [ -s FILE ] 如果 FILE 存在且大小非0时为真则返回为真。@H_301_5@ [ -u FILE ] 如果 FILE 存在且设置了SUID位时返回为真。@H_301_5@ [ -w FILE ] 如果 FILE 存在且是可写的则返回为真。(一个目录为了它的内容被访问必然是可执行的)@H_301_5@ [ -x FILE ] 如果 FILE 存在且是可执行的则返回为真。@H_301_5@ [ -O FILE ] 如果 FILE 存在且属有效用户ID则返回为真。@H_301_5@ [ -G FILE ] 如果 FILE 存在且默认组为当前组则返回为真。(只检查系统默认组)@H_301_5@ [ -L FILE ] 如果 FILE 存在且是一个符号连接则返回为真。@H_301_5@ [ -N FILE ] 如果 FILE 存在 and has been mod如果ied since it was last read则返回为真。@H_301_5@ [ -S FILE ] 如果 FILE 存在且是一个套接字则返回为真。@H_301_5@ [ FILE1 -nt FILE2 ] 如果 FILE1 比 FILE2 新,或者 FILE1 存在但是 FILE2 不存在则返回为真。@H_301_5@ [ FILE1 -ot FILE2 ] 如果 FILE1 比 FILE2 老,或者 FILE2 存在但是 FILE1 不存在则返回为真。@H_301_5@ [ FILE1 -ef FILE2 ] 如果 FILE1 和 FILE2 指向相同的设备和节点号则返回为真。

字符串判断@H_301_5@ [ -z STRING ] 如果STRING的长度为零则返回为真,即空是真@H_301_5@ [ -n STRING ] 如果STRING的长度非零则返回为真,即非空是真@H_301_5@ [ STRING1 ] 如果字符串不为空则返回为真,与-n类似@H_301_5@ [ STRING1 == STRING2 ] 如果两个字符串相同则返回为真@H_301_5@ [ STRING1 != STRING2 ] 如果字符串不相同则返回为真@H_301_5@ [ STRING1 \< STRING2 ] 如果 “STRING1”字典排序在“STRING2”前面则返回为真。比较大小的时候 可以使用大于号,小于号,但是需转义。例如 [ "2006.01.23" \> "2005.03.01" ] && echo dayu || echo budayu@H_301_5@ [ STRING1 \> STRING2 ] 如果 “STRING1”字典排序在“STRING2”后面则返回为真。

数值判断@H_301_5@ [ INT1 -eq INT2 ] INT1和INT2两数相等返回为真,=@H_301_5@ [ INT1 -ne INT2 ] INT1和INT2两数不等返回为真,<>@H_301_5@ [ INT1 -gt INT2 ] INT1大于INT2返回为真,>@H_301_5@ [ INT1 -ge INT2 ] INT1大于等于INT2返回为真,>=@H_301_5@ [ INT1 -lt INT2 ] INT1小于INT2返回为真,<@H_301_5@ [ INT1 -le INT2 ] INT1小于等于INT2返回为真,<=

逻辑判断@H_301_5@ [ ! EXPR ] 逻辑非,如果 EXPR 是false则返回为真。@H_301_5@ [ EXPR1 -a EXPR2 ] 逻辑与,如果 EXPR1 and EXPR2 全真则返回为真。@H_301_5@ [ EXPR1 -o EXPR2 ] 逻辑或,如果 EXPR1 或者 EXPR2 为真则返回为真。@H_301_5@ [ ] || [ ] 用OR来合并两个条件@H_301_5@ [ ] && [ ] 用AND来合并两个条件

IF高级特性:@H_301_5@ 双圆括号(( )):表示数学表达式@H_301_5@ 在判断命令中只允许在比较中进行简单的算术操作,而双圆括号提供更多的数学符号,而且在双圆括号里面的'>','<'号不需要转意。

双方括号[[ ]]:表示高级字符串处理函数@H_301_5@ 双方括号中判断命令使用标准的字符串比较,还可以使用匹配模式,从而定义与字符串相匹配的正则表达式。

双括号的作用:@H_301_5@ 在shell中,[ $a != 1 || $b = 2 ]是不允许出,要用[ $a != 1 ] || [ $b = 2 ],而双括号就可以解决这个问题的,[[ $a != 1 || $b = 2 ]]。又比如这个[ "$a" -lt "$b" ],也可以改成双括号的形式(("$a" < "$b"))

实例

1:判断目录$doiido是否存在,若不存在,则新建一个

if [ ! -d "$doiido"]; then
  mkdir "$doiido"
fi

2:判断普通文件$doiido是否存,若不存在,则新建一个

if [ ! -f "$doiido" ]; then
  touch "$doiido"
fi

3:判断$doiido是否存在并且是否具有可执行权限

if [ ! -x "$doiido"]; then
  mkdir "$doiido"
chmod +x "$doiido"
fi

4:是判断变量$doiido是否有值

if [ ! -n "$doiido" ]; then
  echo "$doiido is empty"
  exit 0
fi

5:两个变量判断是否相等

if [ "$var1" = "$var2" ]; then
  echo '$var1 eq $var2'
else
  echo '$var1 not eq $var2'
fi

6:测试退出状态:

if [ $? -eq 0 ];then
echo 'That is ok'
fi

7:数值的比较:

if [ "$num" -gt "150" ]
echo "$num is biger than 150"
fi

8:a>b且a<c

(( a > b )) && (( a < c ))
[[ $a > $b ]] && [[ $a < $c ]]
[ $a -gt $b -a $a -lt $c ]
[ a > b ] && [ a < c ]

9:a>b或a<c

(( a > b )) || (( a < c ))
[[ $a > $b ]] || [[ $a < $c ]]
[ $a -gt $b -o $a -lt $c ]

10:检测执行脚本的用户

if [ "$(whoami)" != 'root' ]; then
echo "You have no permission to run $0 as non-root user."
exit 1;
fi

上面的语句也可以使用以下的精简语句@H_301_5@ [ "$(whoami)" != 'root' ] && ( echo "You have no permission to run $0 as non-root user."; exit 1 )@H_301_5@ @H_301_5@ 11:正则表达式

doiido="hero"
if [[ "$doiido" == h* ]];then
echo "hello,hero"
fi

猜你在找的Bash相关文章