博客
关于我
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创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(2)~单表查询、mysql查询常用的函数
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
MySQL千万级多表关联SQL语句调优
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>
MySQL单实例或多实例启动脚本
查看>>
MySQL压缩包方式安装,傻瓜式教学
查看>>