编程我们有面向过程

			控制结构
			顺序结构 
			选择结构 if语句
			循环结构 for

选择结构: if:单分支、双分支、多分支 if CONDITION;then 语句 fi if CONDITION;then 语句 else 语句 fi if CONDITION;then 语句 elif CONDITON;then 语句 fi 多分支的语句使用起来是比较慢的,每一个条件都要看

十、case循环 还有一种结构上更为明亮清晰的 其中SWITCH (可以用变量,但是要引用变量的值的,如果是脚本需要输入数值,像$1,就是直接写$1:要加$的,这里支持通配符的,如下面那个例子)

case语句:选择结构 case SWITCH in value1) statement ... ;;双分号结尾,可以写到语句的结尾,如下面那个 value2) statement ...;; 以后用着一种 *) statement ... ;; esac 注意的是:双分号结尾,可以写到语句后面,也可以转行后面 用esac结尾,就是case的反写 *)表示的是其他任何输入的东西就显示以下内容 小例子如下 上面的[0-9]表示的是0到9选一个数字,类似glob通配符匹配

比较难的例子——case也是只是执行其中的一个分支,所以即使你写多个参数,他也只是判断一个就结束了,当然可以让它转一圈再回来,利用for循环可以实现,如下面这个例子

上面两张图片是一个脚本连在一起的程序 第一个带Debug的脚本 上面那个脚本的测试如下

上面脚本写出来如下 #!/bin/bash DEBUG=1 ADD=0 DEL=0

for i in seq 1 $#;do

case $1 in -v|--verbose) DEBUG=1 shift ;; -h|--help) echo "Usage:basename $0 --add User_list --del User_list -v|--verbose -h|--help" exit 0 ;; --add) ADD=1 ADDUSERS=$2 shift 2 ;; --del) DEL=1 DELUSERS=$2 shift 2 ;; #*) #echo "Usage:basename $0 --add User_list --del User_list -v|--verbose -h|--help" #exit 7 esac

done

if [ $ADD -eq 1 ];then for USER in echo $ADDUSERS | sed 's@,@ @g';do if id $USER &> /dev/null;then [ $DEBUG -eq 1 ] && echo "$USER exists." else useradd $USER [ $DEBUG -eq 1 ] && echo "Add user $USER finished." fi done fi if [ $DEL -eq 1 ];then for USER in echo $DELUSERS | sed 's@,@ @g';do if id $USER &> /dev/null;then userdel -r $USER [ $DEBUG -eq 1 ] && echo "Delete $USER finished." else [ $DEBUG -eq 1 ] && echo "$USER not exist." fi done fi 测试结果如下 [root@test1 ~]# ./1.sh --add linan,linan1,linan2,linan3 --del linan3,linan1 Add user linan finished. Add user linan1 finished. linan2 exists. Add user linan3 finished. Delete linan3 finished. Delete linan1 finished.

比如我们测试是./shell --add user1,user2 -v ,那可以看到这里有三个参数,首先$1.$2这两个就被占用了,但是shift 2是退出掉$1,$2的赋值的参数,然后再上去循环的话,第三个参数就变成了第一个参数,因为$1,$2的赋值已经没了,第三个参数变成了$1,然后继续执行case语句,把-v当做$1,就匹配了-v的选项,所以可以这样去循环执行case语句

没那么难的一道练习题

这样子的话就比较像一个脚本了!