Shell编程之条件语句

条件测试操作

要使Shell脚本程序具备一定的"智能"面临的第一个问题就是如何区分不同的情况以确定执行何种操作。

Shell环境根据命令执行后的返回状态值($?)来判断是否行成功,当返回值为0时表示成功,非0时则失败或异常。

使用test时,两种形式作用完全相同,后一种较为常用。([或]与条件表达式之间需至少一个空格。)

文件测试

文件测试指的是根据给定的路径名称,判断对应的是文件还是目录,或者判断文件是否可读、可写、可执行等。

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


  1. [root@localhost ~]# [ -d /media/ ]

  2. [root@localhost ~]# echo $?     //查看前一命令的返回值

  3. 0       //返回0表示条件成立


 若测试的条件不成立,则测试操作的返回值将不为0(通常为为1)。


  1. [root@localhost ~]# [/media/cdrom/Server ]
  2. [root@localhost ~]# echo $?      //查看前一命令的返回值
  3. 1

 


为了更直观地查看测试结果,可以结合命令分隔符"&&"和echo命令一起使用,当条件成立时直接输出
"YES"。其中,"&8"符号表示"而且"的关系,只有当前面的命令执行成功后才会执行后面的命令,否则后面的命令将会被忽略。

[root@localhost ~]# [ -d /media/cdrom/Server ]&& echo "YES"

//无输出表示该目录不存在

  1. [root@localhost ~]# [ -d /media/cdrom ] && echo "YES"    //输出“”“YES”表示该目录存在

  2. YES

整数值比较

整数值比较指的是根据给定的两个整数值,判断第一个数与第二个数的关系,如是否大于、等于、小于第二个数。


eq:第一个数等于(Equal)第二个数。
-ne:第一个数不等于(Not Equal)第二个数。
-gt:第一个数大于(Greater Than)第二个数。
-lt:第一个数小于(LesserThan)第二个数。
-le:第一个数小于或等于(Lesseror Equal)第二个数。
-ge:第一个数大于或等于(Greater or Equal)第二个数。


 
 
  1. [root@localhost ~]# Unum=`who | wc -l` //查看当前已登录用户数

  2. [root@localhost ~]# [ $Unum -gt 5 ] && echo "Too manў."    //测试结果(大于)

  3. Too many


  1. [root@localhost ~]# FreeCC=$(free -m | grep "Mem: '"| awk '{print $6}')

  2. [root@localhost ~]# [ $FreeCC -lt 1024 ] && echo ${FireeCC}MB

  3. 275MB


字符串比较

字符串比较通常用来检查用户输入系统环境等是否满足条件,在提供交互式操作的Shell脚本中,也可用来判断用户输入的位置参数是否符合要求。

=:第一个字符串与第二个字符串相同。
!=:第一个字符串与第二个字符串不相同,其中"!"符号表示取反。
-z:检查字符串是否为空(Zero),对于未定义或赋予空值的变量将视为空串。

例如:若要判断当前系统的语言环境,当发现不是"en.US"时输出出提示信息"Noten.US",执行如下操作

  1. [root@localhost ~]#_echo $LANG    //查看当前的语言环境

  2. zh_CN.UTF-8

  3. [root@localhost ~]# [ $LANG != "en.US" ] && echo "Not en.US   //字符串测试结果(不等于)

  4. Not en.US

在Shell脚本应用中,经常需要用户输入"yes"或"no"来确认某个任务。以下操作展示了确认交互的简单过程,当然,实际使用时还会根据变量"ACK"的取值分别执行进一步的操作。

  1. [root@localhost ~]# read -p "是否覆盖现有文件(yes/no)?" ACK
  2. 是否覆盖现有文件(yes/no)?yes
  3. [root@localhost ~]# [ $ACK = "yes" ] & echo"覆盖"覆盖
  4. [root@localhost~]# read-p"是否覆盖现有文件(yes/no)?" ACK
  5. 是否覆盖现有文件(yes/no)?no
  6. [root@localhost ~]# [$ACK= "no" ] & echo"不覆盖

逻辑测试

逻辑测试指的是判断两个或多个条件之间的依赖关系。当系统任务取决于多个不同的条件时,根据这些条件是否同时成立或者只要有其中一个成立等情况,需需要有一个测试的过程。

&&:逻辑与,表示"而且",只有当前后两个条件都成立田时,整个测试命令的返回值才为0(结果成立)。使用 test命令测试时,"8&"可改为"-a"。

11:逻辑或,表示"或者",只要前后两个条件中有一个成立,整个测试命令的返回值即为0(结)果成立)。使用test命令测试时,"Il"可改为"-o"。

逻辑否,表示"不",只有当指定的条件不成立时,整个测试命令的返回值才为0(结果成立)。

  1. [root@localhost ~]# uname -r      //查看内核版本信息
  2. 3.10.0-514.el7.x86 64
  3. [root@localhost ~]# Mnum=$(uname -r | awk -F. '{print $1}'     //取主版本号
  4. [root@localhost ~]# Snum=$(uname -r | awk -F. '{print 92}')      //取次版本号
  5. [root@localhost ~]# [ $Mnum -ge 3 ] && [ $Snum -gt 4 ] 8& echo   "符合要求"符合要求

if条件语句

if语句结构

if语句是shell脚本中最为常用的流程控制方式,用于根据特定的条件测试结果,分别执行不同的操作。根据不同的复杂程度,if语句的选择解构可以分为三种基本类型,适用于不同的应用场合。

单分支if语句

if语句是shell脚本中最为常用的流程控制方式,用于根据特定的条件测试结果,分别执行不同的操作。

  1. if条件测试操作
  2. then
  3. 命令序列
  4. fi

单分支if语句的执行流程:首先判断条件测试操作的结果,如果返回值为0,表示条件成立,执行then后面的命令序列,一直到遇见fi结束判断为止,继续执行其他脚本代码,如果返回值不为0.则忽略then后面的命令序列,直接跳至fi行以后执行其他脚本代码。

双分支if语句

对于双分支的选择解构,要求针对“”“条件成立”“”“条件不成立”两种情况分别执行不同的操作。双分支if语句的语法格式如下所示。

  1. if条件测试操作
  2. then
  3. 命令序列1
  4. else
  5. 命令序列2
  6. fi

双分支if语句的执行流程:首先判断条件测试操作的结果:如果条件成立。则执行then后面的命令序列1,忽略else及后面的命令序列2,自到遇见fi结束判断:如果条件不成立,则忽略then及后面的命令序列1,直接调至else后面的命令序列2并执行,自到遇见fi结束判断

多分支if语句

由于if语句可以根据测试结果的成立,不成立分别执行操作,所以能够嵌套使用,进行多次判断。

  1. if条件测试操作1
  2. then
  3. 命令序列1
  4. elif条件测试操作2
  5. then
  6. 命令序列2
  7. else
  8. 命令序列3
  9. fi

多分支if语句的执行流程:首先判断条件测试操作1结果,如果条件1成立,则执行命令序列1,然后跳至fi结束判断:如果条件1不成立,则继续判断条件测试操作2的结果,如果条件2成立,则执行命令序列2,然后跳至fi结束判断——如果所有的条件都不满足,则执行else后面的,命令序列n,自到遇见fi结束判断。

case分支语句

语句主要适用于以下情况:某个变量存在多种取值,需要对其中的每一种取值分别执行不同的命令序列。于if语句相似,if需判断多个不同条件,case判断一个变量不同取值。

case语法结构

  1. case 变量值in

  2. 模式1)

  3. 命令序列1

  4. ;;

  5. 模式2)

  6. 命令序列2

  7. ;;

  8. *)

  9. 默认命令序列

  10. esac

 使用case分支语句时,有几个值得注意的特点如下所述。

  • 行尾必须为单词"in",每一模式必须以右括号")"结束。
  • 双分号";;"表示命令序列的结束。
  • 模式字符串中,可以用方括号表示一个连续的范围,如"[0-9]";还可以用竖杠符号"I"表示或,如"A|B"。
  • 最后的"*)"表示默认模式,其中的*相当于通配符。

case语句应用示例

检查用户输入的字符类型

提示用户从键盘输入一个字符,通过 case语句判断该字符是否为字母、数字或者其他控制字符,并给出相应的提示信息。

执行vim hitkey.sh输入
#!/bin/bash
read-p"请输入一个字符,并按 Enter键确认:"KEY
case "$KEY" in
  [a-z][[A-Z])
  echo"您输入的是字母."
;;
[0-9])
  echo"您输入的是数字."
;;
*)
  echo"您输入的是空格、功能键或其他控制字符."
esac

测试并确认hitkey.sh脚本的执行结果如下所示

[root@localhost ~]# ./hitkey.sh

请输入一个字符,并按Enter键确认:k           //输入字母k

请输入的是字母。

[root@localhost ~]# ./hitkey.sh

请输入一个字符,并按Enter键确认:8            //输入数字8

请输入的数字

[root@localhost ~]# ./hitkey.sh

请输入一个字符,并按Enter键确认:^[[19~        //按F8键

您输入的是空格,功能或其他控制字符

编写系统服务脚本

编写一个名为myprog的系统服务脚本,通过位置变量$1指定的start、stop、restart、status等,

分别启动,停止,重启sleep进程,查看sleep进程状态。

[root@localhost ~]# vim hitkey.sh

#!/bin/bash
case "$1" in
start)
    echo-n"正在启动sleep服务..."
    if sleep 7200 &
  then                      //在后台启动sleep进程
    echo "OK"           //停止sleep进程
 fi
;;
stop)
  echo-n"正在停止sleep服务..."pkill"sleep"&>/dev/null
  echo "OK"            //停止sleep进程
;;
status)
  if pgrep "sleep" &>/dev/null ; then           //判断并提示sleep进程状态
  echo"sleep服务已经启动."else
  echo"sleep服务已经停止."
  fi
;;
restart)
  $0 stop
  $0 start
;;
*)                    //默认显示用法信息
echo  "用法:$0{start|stop|status|restart}"
esac


[root@localhost ~]# chmod +x myprog

测试并确认myprog脚本的执行结果如下所示。

[root@localhost ~]# ./myprog start

正在启动sleep服务...OK

[root@localhost ~]# ./myprog status

sleep服务已经启动.

[root@localhost ~]# ./myprog stop

正在停止sleep服务...OK

[root@localhost ~]# ./myprog reload

//未提供此参数,按默认处理

用法:./myprog{start|stop|status|restart}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值