博客
关于我
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 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>