循环语句命令常用于执行一条指令或者一组指令,那么直到条件不在满足时停止,在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 #最后调用总的函数
不够养眼?没有关系,图片如下:
运行结果如下:
写的不好请见谅,毕竟不是专业