循环语句命令常用于执行一条指令或者一组指令,那么直到条件不在满足时停止,在shell脚本中循环语句常见有 while until for select循环语句。
在while循环语句主要用来重复执行一组命令或语句,在企业实际应用中,常用于守护进程持续运行的程序。
1、在这么多语句中,while循环有它的语法格式,如下:
while <条件表达式> do 指令..... done
看到上面的语法感觉还是不明白?没有关系一句话解释:while循环语句会对紧跟在while后面的条件表达式进行判断,那么如果该条件表达式成立,则运行while循环体里面的命令或者语句,每一次执行到done时,就会重新判断while条件表达式是否成立,直到条件表达式不成立时才会退出while循环
看了解释还是不明白? 没有关系如下:
#!/bin/bash while ((5>3)) do echo "yes yes yes" done
刨析:我们可以看到以上就是一组while循环,那么在while后面跟着 ((5>3)),这个就叫做条件表达式,也就是说,如果5>3成立了,那么执行下面的echo "yes yes yes" 最后当我们的语法执行到了done 它还会继续来判断5是否大于3 那么按照我们上面的while循环,这称为死循环!!! 因为5这辈子都是大于3 那么成立了就会一直输出 yes
输入结果如下:
好,到这里应该了解了while循环的基本操作了;
2、在这里我们先了解一下linux中的sleep命令,sleep 1代表休息一秒,sleep 2代表休息2秒 如下:
#!/bin/bash while ((5>3)) do sleep 2 echo "yes yes yes" done
剖析:如果5>3这个条件是成立的,那么在2秒后输出 yes yes yes
3、将负载值追加到log文件中
#!/bin/bash while [ 1 ] do sleep 2 date >> /root/log done
在这里date是获取当前的时间,那么在while后面跟了一个 [ 1 ]这个就代表着这个条件永远都是真的。
4、shell脚本在后台运行
例1:
解释如下:
[root@shell-yankerp ~]# sh a.sh & #运行a.sh 在后台运行 [1] 66727 [root@shell-yankerp ~]# fg #把后台运行的脚本放到前台运行,如果有多个后台运行的话,+编号提出 sh a.sh ^Z #使用ctrl + z来暂停当前的脚本任务 [1]+ 已停止 sh a.sh [root@shell-yankerp ~]# bg #使用bg放在后台运行 [1]+ sh a.sh & [root@shell-yankerp ~]# jobs #使用jobs来查看后台运行的脚本 [1]+ 运行中 sh a.sh & [root@shell-yankerp ~]# fg 1 #fg加编号把后台运行的脚本放置前台 sh a.sh ^Z #执行ctrl + z停止脚本任务 [1]+ 已停止 sh a.sh [root@shell-yankerp ~]# jobs #使用jobs来查看后台运行脚本任务 [1]+ 已停止 sh a.sh [root@shell-yankerp ~]# kill %1 #使用kill + %编号停止运行任务 [1]+ 已停止 sh a.sh [root@shell-yankerp ~]# jobs #jobs再次查看 [1]+ 已终止 sh a.sh [root@shell-yankerp ~]#
图片说明:
4、使用while循环打印5-1
#!/bin/bash a=5 while (($a>0)) do echo $a ((a--)) done
剖析:
a=5是一个变量 while (($a>0)) 也相当于((5>0)) 在这里5肯定>0啊 条件成立 do echo $a 这里就是5 4 3 2 1 直到条件不成立退出循环 ((a--)) 每一次循环 5就 减去1 那么一直循环到5-1 4-1 3-1 2-1 1-1 那么到了1-1=0了 以上条件 0 > 0 不成立 退出循环 done
输出如下:
[root@shell-yankerp ~]# sh a.sh 5 4 3 2 1 [root@shell-yankerp ~]#
应该可以理解,继续使用双中括号演示
#!/bin/bash a=5 while [[ $a>0 ]] do echo $a ((a--)) done
输出如下:
[root@shell-yankerp ~]# sh a.sh 5 4 3 2 1 [root@shell-yankerp ~]#
还有[]号 [ $a -gt 0 ] 这里不在做演示~~~
二、until循环
其实until循环和while循环是相反的,也就是说,当条件表达式不成立时,就会进入循环如下:
#!/bin/bash a=5 until [[ $a < 1 ]] do echo $a ((a--)) done
以上 a=5 $a就是5 那么在以上语句中5<1不成立那么就会进入循环,也就是它是反着的,输出如下:
需求:从1加到100 请用 1+2+3+4这样的计算,如下:
#!/bin/bash a=1 b=0 while (($a <= 100)) do ((b=b+a)) ((a++)) done echo $b
什么意思呢解释如下:
#!/bin/bash a=1 #这是一个变量 a=1 那么a就是1 b=0 #b呢 就是0 while (($a <= 100)) #如果$a <= 100 也就是说 1 <= 100 条件成立 1<=100 do ((b=b+a)) #b=b+a 意思是: b这个变量等于0+1 ((a++)) #a++的意思是 循环一次a就+1 如果不加的话那么条件一直成立就是死循环 done echo $b #================================================================================================== #计算 b=b+a 相当于 0+1 循环到下面 a++ 也就是1+1=2 执行到done 那么再次循环 这里的a等于2了 那么就是 0+1+2+3+4+5+6+.....
图片解释
输出结果如下:
[root@shell-yankerp ~]# sh a.sh 5050 [root@shell-yankerp ~]#
希望读者能懂吧,刚开始确实挺绕,慢慢的就好了
while循环到底有什么用,不会就是上面的去加减吧。实战如下:
1、编写冲手机话费脚本
在书上也有这样的例子,但是我还是按照自己的想法写出来 如下:
#!/bin/bash red_col="\e[1;31m" reset_col="\e[0m" . /etc/init.d/functions zongjia=30 duanxin=15 function caidan(){ cat <<EOF ============================ 1.查询话费 2.发短信 3.充值话费 4.退出 ============================ EOF } function panduan(){ read -p "请您输入你想要的业务:" NUM expr $NUM + 1 &>/dev/null if [ "$?" -ne 0 ] then echo "请您输入{1|2|3|4}" exit 1 fi } function cxdx(){ echo "您好,帅哥,您当前的余额剩余:$zongjia" } function fdx(){ while : do if [ "$zongjia" -lt $duanxin ];then action "您当前的余额不足,请充值!!!" /bin/false return 1 else read -p "请您输入你要发送的内容:" aaa zongjia=$((zongjia-duanxin)) echo "发送成功,当前的余额剩余:$zongjia" return 1 fi done } function czhf(){ while : do read -p "请您输入你要充值的余额:" bbb expr $bb + 1 &>/dev/null if [ "$?" -ne 0 ];then action "请您输入数值" /bin/false exit 1 else zongjia=$((zongjia+$bbb)) echo "充值成功,当前的余额剩余:$zongjia" return 1 fi done } function exit (){ exit 0 } function zong(){ while : do caidan && panduan case $NUM in 1) cxdx ;; 2) fdx ;; 3) czhf ;; 4) exit ;; esac done } zong
看不懂没关系,解释如下:
#!/bin/bash red_col="\e[1;31m" #定义red变量 这个就是为了一个红色 reset_col="\e[0m" #这个也是 . /etc/init.d/functions #加载functions函数库 zongjia=30 #总价为30元 duanxin=15 #一条短信为15元 function caidan(){ #定义菜单函数 cat <<EOF ============================ 1.查询话费 2.发短信 3.充值话费 4.退出 ============================ EOF } function panduan(){ #定义判断函数 read -p "请您输入你想要的业务:" NUM #等待用户输入内容赋值给变量NUM expr $NUM + 1 &>/dev/null #判断用户输入的是否是数值 if [ "$?" -ne 0 ] #如果不是数值 then #那么 echo "请您输入{1|2|3|4}" #输出这条内容 exit 1 #最后退出脚本 fi } function cxdx(){ #定义查询短信函数 echo "您好,帅哥,您当前的余额剩余:$zongjia" #echo 输出此内容 } function fdx(){ #定义发短信的函数 while : #while循环 do if [ "$zongjia" -lt $duanxin ];then #如果总价格小于一条短信的价格 action "您当前的余额不足,请充值!!!" /bin/false #那么输出此内容 return 1 #退出函数 else #否则 read -p "请您输入你要发送的内容:" aaa #等待用户内容赋值给aaa zongjia=$((zongjia-duanxin)) #总价=总价-一条短信的价格 echo "发送成功,当前的余额剩余:$zongjia" #最后输出总价格 return 1 #退出此函数 fi done } function czhf(){ #定义充值话费函数 while : #while循环 do read -p "请您输入你要充值的余额:" bbb #等待用户内容赋值给bbb expr $bb + 1 &>/dev/null #检查用户输入的是否为数值 if [ "$?" -ne 0 ];then #如果不是数值 action "请您输入数值" /bin/false #那么输出一条请您输入数值 exit 1 #退出 else #否则 zongjia=$((zongjia+$bbb)) #总价=总价+用户输入的价格 echo "充值成功,当前的余额剩余:$zongjia" #最后输出总价格 return 1 #退出函数和while循环 fi done } function exit (){ #定义exit退出函数 exit 0 #退出 } function zong(){ #定义总的函数 while : #while循环 do caidan && panduan #调用菜单函数和判断函数 case $NUM in #如果在$NUM这个变量中输入的是以下: 1) cxdx ;; 2) fdx ;; 3) czhf ;; 4) exit ;; esac done } zong #最后调用总的函数
不够养眼?没有关系,图片如下:
运行结果如下:
写的不好请见谅,毕竟不是专业