Linux Shell下条件语句

转自:http://blog.csdn.net/evils798/article/details/8648010
Linux  Shell下条件语句:

1、	测试字符串之间的关系
        bash把所有的命令行和变量都看作字符串。一些命令如expr和test可以把字符当作数字进行操作。同样任何数字也可以作为字符串进行操作。 
  用户可以比较两个字符串相等或不等,也可以测试一个串是否赋了值。有关串的操作符如下:  
    str1 = str2      当两个串有相同内容、长度时为真 
    str1 != str2       当串str1和str2不等时为真  
    -n str1         当串的长度大于0时为真(串非空)  
    -z str1         当串的长度为0时为真(空串)  
    str1           当串str1为非空时为真  
     不但Shell程序可以使用test进行条件判断,test命令也可以独立执行,如:  
    $str1=abcd  
    $test $str1 = abcd  
    $echo $?  
    结果显示:0  
与上例中第一行赋值语句中的等号不同,test命令中的等号两边必须要有空格。本例:test命令共有3个参数。注意两个串相等必须是长度和内容都相等。 
    $str1="abcd "  
    $test "$str1" = abcd  
    $echo $?  
    结果显示:1 
      上面str1包含5个字符,其中最后一个为空格符。而test命令中的另一个串只有4个字符,所以两串不等,test返回1。  
      不带任何操作符和使用-n操作符测试一个串结果是一样的,例如:  
    $str1=abce  
    $test $str1  
    $echo $?  
    结果显示:0     
    $test -n $str1  
    $echo $?  
    结果显示:0 
      但是,上面两条命令也有一点差别,反映出了使用test命令潜在的问题,请看下例:  
    $str1="   "  
    $test $str1  
    $echo $?  
    结果显示:1  
    $test -n "$str1"  
    $echo $?  
    结果显示:0  
    $test -n $str1  
    结果显示:
test:argument expected  
  上例中,第一次测试为假因为Shell在执行命令行之前首先要进行变量替换,即把$str1换成空格,然后shell又将命令行上的空格删除,故 test命令测试到的为空串。而在第二次测试中,变量替换后空格位于括号内,故不会被删除,test测试到的是一个包含空格的串,在第三次测试中, shell把空格删除,只把-n传个test命令,所以显示参数错。
 
2、	测试两个整数之间关系  
test命令与expr命令一样,也可以把字符转变成整数,然后对其操作。test命令对两个数进行比较,使用的操作符如下:  
    int1 -eq int2    两数相等为真  
    int1 -ne int2    两数不等为真 
    int1 -gt int2    int1大于int2为真 
    int1 -ge int2    int1大于等于int2为真  
    int1 -lt int2    int1小于int2为真  
    int1 -le int2    int1小于等于int2为真  
  下面的例子反映了字符串比较与数字比较的不同:  
    $str1=1234  
    $str2=01234  
    $test $str1 = $str2  
    $echo $?  
    结果显示:1  //0为真,1为假;
    $test $str1 -eq $str2  
    $echo $?  
    结果显示:0   //0为真,1为假;

3、	有关文件的测试  
使用test进行的第三类测试是测试文件的状态,用户可以测试文件是否存在,是否可写以及其他文件属性。下面是文件测试时使用的选项。注意只有文件存在时,才有可能为真。  
  -r file     用户可读为真  
  -w file     用户可写为真  
  -x file     用户可执行为真  
  -f file     文件为正规文件为真  
  -d file     文件为目录为真  
  -c file     文件为字符特殊文件为真  
  -b file     文件为块特殊文件为真  
  -s file     文件大小非0时为真  
  -t file     当文件描述符(默认为1)指定的设备为终端时为真

4、	复杂的条件测试(and 、or 、not) 
    -a           与  
  -o          或  
   !          非 
  就是组合条件了,任何高级语言中都有的(NOT 、AND 、OR),例如: 
    $test -r em.null -a -s em.null 
    $echo $? 
    结果显示:1 
    说明了em.null并不是可读并且非空的文件 

5、	另一种执行test的方法  
    bash中还有另一种执行test命令的方法,就是把测试条件放到一对[ ]中,例如:  
    $int1=4  
    $[ $int1 -gt 2 ]  
    $echo $? 
    结果显示:0  
要注意在[ 的后面和 ]符号的前面要有一个空格。  
  下面我们用test命令写个简单但比较完善的程序:  
    #-- 备份程序 
    #-- 检查参数  
    if [ $# -ne 1 ]  
    then  
      echo "请在程序名后面指出要备份文件所在目录!"  
      exit 1  
    fi  
    #-- 检查目录名是否有效  
    if [ !-d "$1" ]  
    then  
      echo "$1 不是一个目录!" 
      exit 2  
    fi 
    cd $1  
    ls -a | cpio -o >/dev/mnt0  
    if [ $? -eq 0 ]  
    then  
      rm *  
    else  
      echo "cpio执行不成功!备份失败..."  
      exit 3  
    fi
 
6、	空命令
        在Bsh中用 : 代表空命令,就是充个数,什么都不做。
        
7、	嵌套if语句和else if 结构
        检查条件1  
A:当条件1为真,则执行一部分操作  
  B:若条件1为假,检查条件2  
    1)若条件2为真,执行另外一部分操作  
    2)若条件2为假,检查条件3  
    3)若条件3为真,执行其他一部分操作  
  语法如下:  
    if command  
    then  
      command  
    else  
      if command  
      then  
        command  
      else 
        if command  
        then  
          command  
        fi  
      fi  
    fi
 
8、	elif语句  
  嵌套if语句有时会给用户带来混乱,特别是什么时候fi语句很难判断。因此Bourne Shell又提供了elif语句。elif是else-if的缩写,它表示是if语句的继续。格式为:  
    if command  
    then  
      command  
    elif command  
    then  
      command  
    elif command 
    then  
      command  
    fi 
上面介绍的嵌套if语句和elif语句完成相同的功能,用户可以根据自己的喜好选择一种使用。
 
9、	case语句  
前面说的elif语句替代if-then-else语句,但有时在编程时还会遇到对同一变量进行多次的测试,该情况可以用多个elif语句实现,但还有一种更简单的方法就是用case语句。   
case语句不但取代了多个elif和then语句,还可以用变量值对多个模式进行匹配,当某个模式与变量值匹配后,其后的一系列命令将被执行,下面是case语句使用的语句。  
  case value in  
   pattem 1)  
    command  
    command;;  
   pattem 2)  
    command  
    command;;  
   ....  
   pattem)  
    command;  
  esac  
  case语句只执行其中的一组命令,当变量值与多个模式相匹配时,只有第一个匹配的模式对应的命令被执行。";;"表示该模式对应的命令部分程序。  
  通过学习下面的read语句,我们们再举例子说明case语句的用法。

10、	read语句  
 Shell程序不但可以通过命令行参数得到输入数据,还可以使用read命令提示用户输入数据,其语法格式为:  
  read var1 var2... ...varn  
当Bash 遇到一个read语句时,在标准输入文件中读取数据直到一个换行符。此时Shell在解释输入行时,不进行文件名或变量的替换,只是简单地删除多余的空格。然后Shell将输入行的第一个字的内容给变量1,第二个给变量2,直到所有变量都赋上值或是输入行为空。若输入行中字的个数超过变量个数, Shell将把输入行中剩余的所有字的内容都赋给最后一个变量。当变量个数多于输入行字的个数时候,多于的变量将赋一个空值。输入行的每一个字是由空格分隔的一个字母和数字组成的字符串。
 $read var1 var2 var3  
    输入:Hello my friend 
  $echo $var1 $var2 $var3  
    结果显示:Hello my friend  
  $echo $var2  
    结果显示:my 

下面用个read和case的例子结束本部分的学习:  
  #--交互式备份,恢复程序  
  echo "输入要备份文件所在目录:\c"  
  read WORKDIR  
  if [ !-d $WORKDIR ]  
  then  
    echo "Sorry,$WORKDIR is not a directory"  
    exit 1  
  fi  
  cd $WORKDIR  
  echo "输入选择:"  
  echo _  
  echo "1.恢复到 $WORKDIR"  
  echo "2.备份 $WORKDIR"  
  echo "0.退出"  
  echo  
  echo "\c"  
  read CHOICE  
  case "$CHOICE" in  
echo "恢复中... ..."  
    cpio -i < /dev/mnt0;;  
echo "备份中... ..."  
    ls | cpio -o > /dev/mnt0;;  	
   0)exit 1  
   *)exit 1  
esac  
  if [ $? -ne 0 ]  
  then  
   echo "程序运行中出现错误!"  
  else  
   echo "操作成功!"  
fi    
  在上面代码中,"*"定义了其他模式下不匹配时的默认操作。  
循环语句  
  前面介绍的程序和所学的语句都是从头到尾成一条主线下来,或是成分支结构,在日常管理UNIX的过程中,经常要重复的做一些操作,处理批量的问题,这就涉及到了循环结构,同高级语言相似,UNIX的Shell也提供了强大的循环处理语句。  
  Bsh语言中有三种循环语句-while循环、until循环、for循环,下面通过具体的例子分别介绍这三种结构。  
While循环  
  在while循环语句中,当某一条件为真时,执行指定的命令。语句的结构如下:  
while command  
do  
  command 
  command  
  … …  
done  
示例代码如下:
  
#测试while循环小程序  
x_t=1  
  while [  $x_t -lt 5 ]  
  do  
     mm=` expr $x_t \* $int `  #注意"\"的作用
     echo "$mm"  
     x_t=` expr $x_t + 1 `   #注意expr的用法  
  done  
  echo "THE WHILE IS END!\n"  
程序的执行结果如下:  
1  
4  
9  
16  
THE WHILE IS END 
 
  在上述程序中,当变量x_t的值小于5的时候,执行while循环中的语句。在第五次循环时, [ $x_t-lt5]命令返回非零值,于是程序执行done后面的代码。  
现在利用while循环,可以改进我们早些时候用的备份数据的例子,当用户指定的目录备份完毕后,使用while循环使程序执行一次可以备份多个用户指定的目录。代码如下:  
echo "欢迎使用备份小程序"  
  ANS=Y  
  while [ $ANS = Y -o $ANS = y ]  
  do  
    echo _  
    #读目录名  
    echo "输入要备份的目录名:\c"  
    read DIR  
    if [ ! -d $DIR ]  
    then  
        echo "$DIR不是一个目录!"  
        exit 1  
    fi  
    cd $DIR  
    echo "请选择:"  
    echo _  
    echo "1 恢复数据到 $DIR"  
    echo "2 备份$DIR的数据"  
    echo  
    echo "请选择:\c" 
    read CHOICE  
    case "$CHOICE" in  
       1) echo "恢复中… …"  
        cpio -i        2) echo "备份中… …"  
        cpio -o >/dev/rmt0;;  
       *) echo "选择无效"  
    esac  
    if [ $? -ne 0 ]  
    then  
       echo "cpio执行过程中出现问题"  
       exit 2  
    fi  
    echo "继续别的目录吗?(Y/y)\c"  
    read ANS  
  done  
在程序开始,我们给变量ANS符值为Y,根据whlie的判断条件,程序进入while循环,执行do-done中的语句,每次循环都要求用户输入 ANS的值用来判断是否进行下次重复执行do-done中的语句。如果用户输入的条件不满足while语句条件,循环结束,程序执行done后面的语句。

转自:http://blog.csdn.net/evils798/article/details/8648010
Linux  Shell下条件语句:

1、	测试字符串之间的关系
        bash把所有的命令行和变量都看作字符串。一些命令如expr和test可以把字符当作数字进行操作。同样任何数字也可以作为字符串进行操作。 
  用户可以比较两个字符串相等或不等,也可以测试一个串是否赋了值。有关串的操作符如下:  
    str1 = str2      当两个串有相同内容、长度时为真 
    str1 != str2       当串str1和str2不等时为真  
    -n str1         当串的长度大于0时为真(串非空)  
    -z str1         当串的长度为0时为真(空串)  
    str1           当串str1为非空时为真  
     不但Shell程序可以使用test进行条件判断,test命令也可以独立执行,如:  
    $str1=abcd  
    $test $str1 = abcd  
    $echo $?  
    结果显示:0  
与上例中第一行赋值语句中的等号不同,test命令中的等号两边必须要有空格。本例:test命令共有3个参数。注意两个串相等必须是长度和内容都相等。 
    $str1="abcd "  
    $test "$str1" = abcd  
    $echo $?  
    结果显示:1 
      上面str1包含5个字符,其中最后一个为空格符。而test命令中的另一个串只有4个字符,所以两串不等,test返回1。  
      不带任何操作符和使用-n操作符测试一个串结果是一样的,例如:  
    $str1=abce  
    $test $str1  
    $echo $?  
    结果显示:0     
    $test -n $str1  
    $echo $?  
    结果显示:0 
      但是,上面两条命令也有一点差别,反映出了使用test命令潜在的问题,请看下例:  
    $str1="   "  
    $test $str1  
    $echo $?  
    结果显示:1  
    $test -n "$str1"  
    $echo $?  
    结果显示:0  
    $test -n $str1  
    结果显示:
test:argument expected  
  上例中,第一次测试为假因为Shell在执行命令行之前首先要进行变量替换,即把$str1换成空格,然后shell又将命令行上的空格删除,故 test命令测试到的为空串。而在第二次测试中,变量替换后空格位于括号内,故不会被删除,test测试到的是一个包含空格的串,在第三次测试中, shell把空格删除,只把-n传个test命令,所以显示参数错。
 
2、	测试两个整数之间关系  
test命令与expr命令一样,也可以把字符转变成整数,然后对其操作。test命令对两个数进行比较,使用的操作符如下:  
    int1 -eq int2    两数相等为真  
    int1 -ne int2    两数不等为真 
    int1 -gt int2    int1大于int2为真 
    int1 -ge int2    int1大于等于int2为真  
    int1 -lt int2    int1小于int2为真  
    int1 -le int2    int1小于等于int2为真  
  下面的例子反映了字符串比较与数字比较的不同:  
    $str1=1234  
    $str2=01234  
    $test $str1 = $str2  
    $echo $?  
    结果显示:1  //0为真,1为假;
    $test $str1 -eq $str2  
    $echo $?  
    结果显示:0   //0为真,1为假;

3、	有关文件的测试  
使用test进行的第三类测试是测试文件的状态,用户可以测试文件是否存在,是否可写以及其他文件属性。下面是文件测试时使用的选项。注意只有文件存在时,才有可能为真。  
  -r file     用户可读为真  
  -w file     用户可写为真  
  -x file     用户可执行为真  
  -f file     文件为正规文件为真  
  -d file     文件为目录为真  
  -c file     文件为字符特殊文件为真  
  -b file     文件为块特殊文件为真  
  -s file     文件大小非0时为真  
  -t file     当文件描述符(默认为1)指定的设备为终端时为真

4、	复杂的条件测试(and 、or 、not) 
    -a           与  
  -o          或  
   !          非 
  就是组合条件了,任何高级语言中都有的(NOT 、AND 、OR),例如: 
    $test -r em.null -a -s em.null 
    $echo $? 
    结果显示:1 
    说明了em.null并不是可读并且非空的文件 

5、	另一种执行test的方法  
    bash中还有另一种执行test命令的方法,就是把测试条件放到一对[ ]中,例如:  
    $int1=4  
    $[ $int1 -gt 2 ]  
    $echo $? 
    结果显示:0  
要注意在[ 的后面和 ]符号的前面要有一个空格。  
  下面我们用test命令写个简单但比较完善的程序:  
    #-- 备份程序 
    #-- 检查参数  
    if [ $# -ne 1 ]  
    then  
      echo "请在程序名后面指出要备份文件所在目录!"  
      exit 1  
    fi  
    #-- 检查目录名是否有效  
    if [ !-d "$1" ]  
    then  
      echo "$1 不是一个目录!" 
      exit 2  
    fi 
    cd $1  
    ls -a | cpio -o >/dev/mnt0  
    if [ $? -eq 0 ]  
    then  
      rm *  
    else  
      echo "cpio执行不成功!备份失败..."  
      exit 3  
    fi
 
6、	空命令
        在Bsh中用 : 代表空命令,就是充个数,什么都不做。
        
7、	嵌套if语句和else if 结构
        检查条件1  
A:当条件1为真,则执行一部分操作  
  B:若条件1为假,检查条件2  
    1)若条件2为真,执行另外一部分操作  
    2)若条件2为假,检查条件3  
    3)若条件3为真,执行其他一部分操作  
  语法如下:  
    if command  
    then  
      command  
    else  
      if command  
      then  
        command  
      else 
        if command  
        then  
          command  
        fi  
      fi  
    fi
 
8、	elif语句  
  嵌套if语句有时会给用户带来混乱,特别是什么时候fi语句很难判断。因此Bourne Shell又提供了elif语句。elif是else-if的缩写,它表示是if语句的继续。格式为:  
    if command  
    then  
      command  
    elif command  
    then  
      command  
    elif command 
    then  
      command  
    fi 
上面介绍的嵌套if语句和elif语句完成相同的功能,用户可以根据自己的喜好选择一种使用。
 
9、	case语句  
前面说的elif语句替代if-then-else语句,但有时在编程时还会遇到对同一变量进行多次的测试,该情况可以用多个elif语句实现,但还有一种更简单的方法就是用case语句。   
case语句不但取代了多个elif和then语句,还可以用变量值对多个模式进行匹配,当某个模式与变量值匹配后,其后的一系列命令将被执行,下面是case语句使用的语句。  
  case value in  
   pattem 1)  
    command  
    command;;  
   pattem 2)  
    command  
    command;;  
   ....  
   pattem)  
    command;  
  esac  
  case语句只执行其中的一组命令,当变量值与多个模式相匹配时,只有第一个匹配的模式对应的命令被执行。";;"表示该模式对应的命令部分程序。  
  通过学习下面的read语句,我们们再举例子说明case语句的用法。

10、	read语句  
 Shell程序不但可以通过命令行参数得到输入数据,还可以使用read命令提示用户输入数据,其语法格式为:  
  read var1 var2... ...varn  
当Bash 遇到一个read语句时,在标准输入文件中读取数据直到一个换行符。此时Shell在解释输入行时,不进行文件名或变量的替换,只是简单地删除多余的空格。然后Shell将输入行的第一个字的内容给变量1,第二个给变量2,直到所有变量都赋上值或是输入行为空。若输入行中字的个数超过变量个数, Shell将把输入行中剩余的所有字的内容都赋给最后一个变量。当变量个数多于输入行字的个数时候,多于的变量将赋一个空值。输入行的每一个字是由空格分隔的一个字母和数字组成的字符串。
 $read var1 var2 var3  
    输入:Hello my friend 
  $echo $var1 $var2 $var3  
    结果显示:Hello my friend  
  $echo $var2  
    结果显示:my 

下面用个read和case的例子结束本部分的学习:  
  #--交互式备份,恢复程序  
  echo "输入要备份文件所在目录:\c"  
  read WORKDIR  
  if [ !-d $WORKDIR ]  
  then  
    echo "Sorry,$WORKDIR is not a directory"  
    exit 1  
  fi  
  cd $WORKDIR  
  echo "输入选择:"  
  echo _  
  echo "1.恢复到 $WORKDIR"  
  echo "2.备份 $WORKDIR"  
  echo "0.退出"  
  echo  
  echo "\c"  
  read CHOICE  
  case "$CHOICE" in  
echo "恢复中... ..."  
    cpio -i < /dev/mnt0;;  
echo "备份中... ..."  
    ls | cpio -o > /dev/mnt0;;  	
   0)exit 1  
   *)exit 1  
esac  
  if [ $? -ne 0 ]  
  then  
   echo "程序运行中出现错误!"  
  else  
   echo "操作成功!"  
fi    
  在上面代码中,"*"定义了其他模式下不匹配时的默认操作。  
循环语句  
  前面介绍的程序和所学的语句都是从头到尾成一条主线下来,或是成分支结构,在日常管理UNIX的过程中,经常要重复的做一些操作,处理批量的问题,这就涉及到了循环结构,同高级语言相似,UNIX的Shell也提供了强大的循环处理语句。  
  Bsh语言中有三种循环语句-while循环、until循环、for循环,下面通过具体的例子分别介绍这三种结构。  
While循环  
  在while循环语句中,当某一条件为真时,执行指定的命令。语句的结构如下:  
while command  
do  
  command 
  command  
  … …  
done  
示例代码如下:
  
#测试while循环小程序  
x_t=1  
  while [  $x_t -lt 5 ]  
  do  
     mm=` expr $x_t \* $int `  #注意"\"的作用
     echo "$mm"  
     x_t=` expr $x_t + 1 `   #注意expr的用法  
  done  
  echo "THE WHILE IS END!\n"  
程序的执行结果如下:  
1  
4  
9  
16  
THE WHILE IS END 
 
  在上述程序中,当变量x_t的值小于5的时候,执行while循环中的语句。在第五次循环时, [ $x_t-lt5]命令返回非零值,于是程序执行done后面的代码。  
现在利用while循环,可以改进我们早些时候用的备份数据的例子,当用户指定的目录备份完毕后,使用while循环使程序执行一次可以备份多个用户指定的目录。代码如下:  
echo "欢迎使用备份小程序"  
  ANS=Y  
  while [ $ANS = Y -o $ANS = y ]  
  do  
    echo _  
    #读目录名  
    echo "输入要备份的目录名:\c"  
    read DIR  
    if [ ! -d $DIR ]  
    then  
        echo "$DIR不是一个目录!"  
        exit 1  
    fi  
    cd $DIR  
    echo "请选择:"  
    echo _  
    echo "1 恢复数据到 $DIR"  
    echo "2 备份$DIR的数据"  
    echo  
    echo "请选择:\c" 
    read CHOICE  
    case "$CHOICE" in  
       1) echo "恢复中… …"  
        cpio -i        2) echo "备份中… …"  
        cpio -o >/dev/rmt0;;  
       *) echo "选择无效"  
    esac  
    if [ $? -ne 0 ]  
    then  
       echo "cpio执行过程中出现问题"  
       exit 2  
    fi  
    echo "继续别的目录吗?(Y/y)\c"  
    read ANS  
  done  
在程序开始,我们给变量ANS符值为Y,根据whlie的判断条件,程序进入while循环,执行do-done中的语句,每次循环都要求用户输入 ANS的值用来判断是否进行下次重复执行do-done中的语句。如果用户输入的条件不满足while语句条件,循环结束,程序执行done后面的语句。

猜你喜欢

转载自blog.csdn.net/MaoshiYIHAO/article/details/77188822