博客
关于我
Shell编程之条件语句(if语句,case分支语句)
阅读量:376 次
发布时间:2019-03-05

本文共 1501 字,大约阅读时间需要 5 分钟。

Shell编程之条件语句

一、条件测试操作

1.test命令

测试表达式是否成立,若不成立返回0,否则返回其他数值

格式1:test 条件表达式格式2:[ 条件表达式 ]

2.文件测试

[ 操作符 文件或目录 ]

常用的测试操作符

常用的操作符 作用
-d 测试是否为目录(Directory)
-e 测试目录或文件是否存在(Exist)
-f 测试是否为文件(File)
-r 测试当前用户是否有权限读取(Read)
-w 测试当前用户是否有权限写入(Write)
-x 测试当前用户是否有权限执行(Excute)

在这里插入图片描述

在这里插入图片描述

3.整数值比较

[ 整数1 操作数 整数2 ]
常用的测试操作符:-eq      #等于(Equal)-ne      #不等于(Not Equal)-gt      #大于(Greater Than)-lt      #小于(Lesser Than)-le      #小于或等于(Lesser or Equal)-ge      #大于或等于(Greater or Equal)

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

4.字符串比较

格式1  [ 字符串1 = 字符串2 ]       [ 字符串1 != 字符串2 ] 格式2 [ -z 字符串 ]
=:第一个字符串与第二个字符串相同!=:第一个字符与第二个字符串不相同,“!”表示取反-z:字符串内容为空-n:是否有字符串存在

在这里插入图片描述

5.逻辑测试

格式1:[ 表达式1 ] 操作符 [ 表达式2 ]格式2:命令1 操作符 命令2

常用的操作符:

-a或&& :逻辑与,“而且”的意思,前后条件需都成立-o或|| :逻辑或,“或者”的意思,只需前后条件中一个成立! :逻辑否
a=5[ $a -ne 1 ] && [ $a != 2 ]	等同于	[ $a -ne 1 -a $a != 2 ]#、&&、||操作符能够正常存在于[[ ]]条件判断结构中,但是如果出现在[ ]结构中的话,会报错[[ $a -ne 1 && $a != 2 ]][ 2 -lt 3 ] && echo true || echo false[ 2 -ge 3 ] && echo true || echo false

在这里插入图片描述

vim pinghost.sh#!/bin/bashping -c 3 -i 0.5 -W 2 $1 &> /dev/null && echo "$1 online" || echo "$1 off"-c:发送包的个数-i:发送包的间隔时间-W:超时时间-w:多少秒后停止 ping 命令操作

在这里插入图片描述

在这里插入图片描述

二、if语句

单分支结构

在这里插入图片描述

格式:if 条件测试操作then命令序列fi
三种表达方式方法一:if [ 3 -gt 2 ] then echo "ok"fi方法二:if [ 3 -gt 2 ]; then echo "ok"; fi方法三:[ 3 -gt 2 ] && echo "ok"

在这里插入图片描述

双分支结构

在这里插入图片描述

格式:if 条件测试操作then命令序列 1else命令序列 2fi

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

多分支结构

在这里插入图片描述

格式:if 条件测试操作 1then命令序列 1elif 条件测试操作 2then命令序列 2[else][命令序列 3]fi

示例:提示用户输入100米赛跑的秒数,要求判断秒数大于0且小于等于10秒的进入选拔赛,大于10秒的都淘汰,

如果输入其它字符则提示重新输入;进入选拔赛的成员再进一步判断男女性别,男生进男生组,女生进女生组,如果输入错误请提示错误
在这里插入图片描述
在这里插入图片描述

三、case分支语句

case 变量值 in 模式一)   命令序列;;模式二)   命令序列 ;;……*)   默认命令序列esac

在这里插入图片描述

示例:

在这里插入图片描述
在这里插入图片描述

转载地址:http://uwag.baihongyu.com/

你可能感兴趣的文章
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>