打响2018第一炮-shell编程之for循环语句

前端之家收集整理的这篇文章主要介绍了打响2018第一炮-shell编程之for循环语句前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

大家好,先祝大家2018新年快乐~~~~

今天给大家带来的是for循环


1.for循环语句和while循环类似,但是for循环主要是用于执行次数有限的循环而不是守护进程及无限循环,那么for循环的语法如下:

@H_404_37@for 变量名 in 变量取值列表 do 指令 done

在这种for循环语法中,在for关键字后面会有一个变量名,变量名会依次的获取in后面的变量取值列表的内容,每取一个然后循环do 和done之间的部分 也就是指令。 之后再次循环下一个变量取值列表 然后执行do done之间的部分,直到变量取值列表的最后一个值并进入循环体后才结束。


2.第二种语法就是C语言型的for循环语句如下:

@H_404_37@for ((exp1;exp2;exp3)) do 指令 done

例如1:

@H_404_37@for ((a=1;a<=10;a++)) do echo $a done

输出结果如下:

@H_404_37@[root@yankerp shell]# sh for_check.sh 1 2 3 4 5 6 7 8 9 10 [root@yankerp shell]#

剖析:

@H_404_37@for ((a=1;a<=10;a++)) #a=1 那么a就是1 a<=10 那么1<10 但是不等于10 所以后面a++增加1 do echo $a #第一次输入$a是1 那么第二次 a++ 等于a+1 也就是1+1 第二次输出2 直到a=10 done #结束

以上的for循环类似于while语句 如下:

@H_404_37@a=1 while ((a<=10)) do echo $a ((a++)) done

输出结果如下:

@H_404_37@[root@yankerp shell]# sh while.sh 1 2 3 4 5 6 7 8 9 10 [root@yankerp shell]#

如果希望程序能够持续运行,那么while循环是最好的选择。

如果是限次循环的话,则多用for循环!!!


3、for循环的基础实践

例1:使用for循环打印 1 2 3 4 5 数字如下:

@H_404_37@#!/bin/bash for zhangsan in 1 2 3 4 5 do echo $zhangsan done

剖析如下:


for关键字后面会有一个变量名,变量名会依次的获取in后面的变量取值列表的内容,每取一个然后循环do 和done之间的部分 也就是指令。 之后再次循环下一个变量取值列表 后执行do done之间的部分,直到变量取值列表的最后一个值并进入循环体后才结束。

最后输出内容

@H_404_37@[root@yankerp shell]# sh for_check.sh 1 2 3 4 5 [root@yankerp shell]#


例如2:使用{}来打印1 2 3 4 5

在前几篇文章中有提过{}的用处,例如打印1-15 或者 a-z

@H_404_37@[root@yankerp shell]# echo {1..15} 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 [root@yankerp shell]# echo {a..z} a b c d e f g h i j k l m n o p q r s t u v w x y z [root@yankerp shell]#

使用for循环结合{}循环

@H_404_37@[root@yankerp shell]# cat for_check.sh #!/bin/bash for zhangsan in {1..5} #或者 {a..z} do echo $zhangsan done [root@yankerp shell]# sh for_check.sh 1 2 3 4 5 [root@yankerp shell]#

输出a-z

@H_404_37@[root@yankerp shell]# sh for_check.sh a b c d e f g h i j k l m n o p q r s t u v w x y z [root@yankerp shell]#


实例3:批量修改文件后缀


我们看到 在这个目录下有这么多文件,但是他们的后缀名不同,但是需求就是我想把以txt格式的文件,都改为.sh的 第一种方法,一条条的手动改,第二种方法如下:

1.首先我们要改后缀名,我们先定义一个变量测试

@H_404_37@[root@yankerp data]# aaa=csdn.txt [root@yankerp data]# echo $aaa csdn.txt [root@yankerp data]# echo $aaa | cut -d . -f1 csdn [root@yankerp data]# echo "`echo $aaa | cut -d . -f1`".sh csdn.sh [root@yankerp data]#

剖析如下:

@H_404_37@[root@yankerp data]# aaa=csdn.txt #定义一个变量 aaa=csdn.txt 那么aaa就是csdn.txt [root@yankerp data]# echo $aaa#echo $aaa 就是 csdn.txt csdn.txt #输出的结果 [root@yankerp data]# echo $aaa | cut -d . -f1 #在这里我们使用cut命令通过.为分隔符截取第一段 csdn#截出来的csdn 那么我们想,这时候在csdn后面加上一个.sh 是不是就好了 如下: [root@yankerp data]# echo "`echo $aaa | cut -d . -f1`".sh#在以上的命令后面加上.sh 就实现了这个效果 csdn.sh [root@yankerp data]#


以上是一个变量的方法,那么接下来编写for循环修改的方式

2.我们是需要把txt后缀改为sh结尾,那么我们肯定是要找出在这里目录下所有以txt文件结尾的文件如下:

@H_404_37@[root@yankerp data]# ls | grep txt$ a.txt b.txt c.txt d.txt uuub.txt [root@yankerp data]#

到这里我想应该很清楚了,接下来修改的方式和上面变量的方式一样 如下:

@H_404_37@#!/bin/bash cd /root/data || { echo "进入目录失败!!!" exit 1 } for zhangsan in `ls | grep txt$` do mv $zhangsan `echo $zhangsan | cut -d . -f1`.sh done

3.剖析:

@H_404_37@#!/bin/bash cd /root/data || { #进入文件目录 echo "进入目录失败!!!" #判断是否进入成功!!! exit 1 } for zhangsan in `ls | grep txt$` #张三是一个变量 那么后面跟着那条命令 也就是所有以txt结尾的文件,开始循环 do mv $zhangsan `echo $zhangsan | cut -d . -f1`.sh #这个就是上面的那个变量的命令。 done

修改如下:



实例4:批量解压文件,如下:


在这个目录下我们看到有很多的包,但是有.tar.gz 的 有rar的 有zip的包,但是呢,我就想解压.tar.gz的包,第一种方法,手动一个个解压,那么第二种方式如下:

1.查看以.tar.gz的包有几个


2.编写脚本如下:

@H_404_37@#!/bin/bash cd /root/data || { echo "进入目录失败!!!" exit 1 } for zhangsan in `ls | grep .tar.gz$` do tar zxf $zhangsan -C /root/log done if [ "$?" -eq 0 ];then echo ".tar.gz 成功!!!" else echo "失败!!!" fi


运行结果如下:



实例5:开发批量创建用户脚本

首先批量创建用户还是很好实现的,如下:

@H_404_37@#!/bin/bash NAME=yankai for zhangsan in `seq -w 1 5` do useradd $NAME$zhangsan done if [ "$?" -eq 0 ];then echo "创建用户成功!!!" else echo "创建用户失败!!!" exit 1 fi

运行如下:


但是问题来了,怎么去给用户加密码,用户是肯定需要密码的,普通我们给一个用户设置密码如下:

@H_404_37@[root@yankerp ~]# echo 123456 | passwd --stdin zhangsan 更改用户 zhangsan 的密码 。 passwd:所有的身份验证令牌已经成功更新。 [root@yankerp ~]#

我们随机匹配密码可以通过$RANDOM|md5sum进行加密的方式来截取前8位 如下:


那么接下来我们就有一定的思路去写脚本了如下:

@H_404_37@#!/bin/bash . /etc/init.d/functions NAME=yankai ZF=`seq 1 10` for user in $ZF do useradd $NAME$user PASS="`echo $RANDOM|md5sum | cut -c 1-8`" echo "$PASS" | passwd --stdin $NAME$user &>/dev/null echo "$NAME$user的密码为:$PASS" if [ "$?" -eq 0 ] then action "$NAME$user is ok!" /bin/true else action "$NAME$user not ok!" /bin/false exit 1 fi done

执行如下:


剖析如下:

@H_404_37@#!/bin/bash . /etc/init.d/functions #加载函数库 NAME=yankai #定义名字为yankai ZF=`seq 1 10` #这个取1-10的数字 for user in $ZF #for循环 user是变量 $ZF取数值 do useradd $NAME$user #创建yankai账户并+1 PASS="`echo $RANDOM|md5sum | cut -c 1-8`" #定义随机密码 取前8位 echo "$PASS" | passwd --stdin $NAME$user &>/dev/null #设置用户密码 echo "$NAME$user的密码为:$PASS" #输出用户密码 if [ "$?" -eq 0 ] #进行判断 then action "$NAME$user is ok!" /bin/true else action "$NAME$user not ok!" /bin/false exit 1 fi done #以上内容一直循环 直到seq 1-10 已经达到了10 那么退出循环!!


案例6:开发检测URL脚本

内容如下:

@H_404_37@#!/bin/bash . /etc/init.d/functions function URL_Check(){ wget --spider http://$1 &>/dev/null if [ "$?" -eq 0 ]; then action "$1 检测成功!" /bin/true else action "$1 检测失败!" /bin/false fi } web=" www.baidu.com www.jd.com www.taobao.com www.4399.com www.baidu123.com www.ywydhajkw.com www.hahahhaha.conm www.dhadwkldm.com " for url in $web do URL_Check $url done

运行结果如下:


以上仅供参考,若写的不好,请见谅,非专业

剖析如下:



最后,再次祝大家新的一年能够开开心心,心想事成,技术越来越牛叉!!!

再见~~~

猜你在找的Bash相关文章