博客
关于我
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整库导入、导出
查看>>
mysql文本函数和数字函数
查看>>
Mysql新建用户和数据库并授权
查看>>
mysql日志
查看>>
mysql日志 事务问题_mysql因为事务日志问题无法启动
查看>>
mysql日志文件
查看>>
mysql日志管理学习笔记
查看>>
mysql日志问题定位实用命令
查看>>
MySQL日期时间函数大全
查看>>
mysql时间相减的问题
查看>>
mysql时间表示和计算
查看>>
MySQL是如何做容器测试的?
查看>>
mysql更改数据库表utf-8_修改mysql数据库为 utf-8
查看>>
mysql更改表引擎INNODB为MyISAM的方法总结
查看>>
mysql更新一个表里的字段等于另一个表某字段的值
查看>>
Mysql更新时间列只改日期为指定日期不更改时间
查看>>
MySQL更新锁(for update)摘要
查看>>
mysql更新频率_MySQL优化之如何了解SQL的执行频率
查看>>
mysql替换表的字段里面内容
查看>>
MySQL最多能有多少连接
查看>>