脚本入门之for循环

面向过程的编译语句,语言控制结构:

顺序执行:默认法则,逐条执行各语句

选择执行:条件判断,只有部分是符合条件,只执行符合条件的部分

布尔测试:真,假(0:真;1-255:假);

循环执行:将同一段代码反复执行n次;循环必须要有退出条件,否则就成为了死循环。


控制语句:

     bash循环控制语句:

              for

              while

              until

bash的for循环:

      事先提供一个元素列表,而后,使用变量去遍历此元素列表;每访问一个元素,就会执行一次循环体;直到元素遍历完毕

用法格式:

        for VAR_NAME in 元素(列表)1 元素(列表)2…

        do

语句1

语句2

           …

        done

注:for和do可以写在同一行中但必须用分号隔开


对于这些知识的运用只能在练习中不断练习才能达到牢固掌握。


练习1:写一个脚本

      使用for循环创建目录/tmp/1.dir,/tmp/2.dir和/tmp/3.dir,并将它们的权限均修改为750;


#!/bin/bash


for DirName in/tmp/1.dir /tmp/2.dir /tmp/3.dir; do

 mkdir $DirName

 chmod 750 $DirName

done


ls –l /tmp 验证一下


练习2:写一个脚本

使用for循环修改目录/tmp/1.dir,/tmp/2.dir和/tmp/3.dir的最近一次修改时间为2010年3月3号3点3分3秒;

#!/bin/bash


for Dir in/tmp/1.dir /tmp/2.dir /tmp/3.dir

do

touch -mt201003030303.03 $Dir

done


stat/tmp/1.dir  查看结果

或:#!/bin/bash

for Dir in/tmp/1.dir /tmp/2.dir /tmp/3.dir

do

stat $Dir

touch -mt201003030303.03 $Dir

stat $Dir

done


练习3:写一个脚本

使用for循环统计/etc/fstab、/etc/rc.d/rc.sysinit、/etc/inittab文件中各自以#开头的行的行数;

        #!/bin/bash

for File in/etc/fstab /etc/rc.d/rc.sysinit /etc/inittab

do

grep '^#.*' $ File| wc -l

done


人性化写法:

#!/bin/bash

for File in/etc/fstab /etc/rc.d/rc.sysinit /etc/inittab ; do

    LINES=`grep '^#' $File | wc -l`

    echo "$File:$LINES"

done


#!/bin/bash

for File in/etc/fstab /etc/rc.d/rc.sysinit /etc/inittab; do

    LINES=$(grep '^#' $File | wc -l)

    echo "$File:$LINES"

done


练习4:写一个脚本

使用for循环统计/etc/fstab、/etc/rc.d/rc.sysinit、/etc/inittab文件中各自以#开头的行的行数和空白行数;

#!/bin/bash

for File in/etc/fstab /etc/rc.d/rc.sysinit /etc/inittab;do

 echo "$File:"

 echo "lines:`grep "^#" $File |wc -l`"

 echo "space lines:`grep "^$"$File | wc -l`"

done


练习5:写一个脚本

使用for循环,复制/etc/fstab、/etc/inittab和/etc/rc.d/init.d/functions文件至/tmp/目录中,并重命名为原有的名称之后加当前日期,如第一个文件为/tmp/fstab-2013-07-15

#!/bin/bash

for File in/etc/fstab /etc/inittab /etc/rc.d/init.d/functions; do

 cp $File /tmp/$File-`date +%F`

done

练习6:写一个脚本

     显示/etc/passwd文件中第1、3、6、12个用户的用户名、ID和shell

#! /bin/bash

for Line in 1 3 6 12;do

UserName=`head -$Line /etc/passwd | tail -1 | cut -d: -f1`

        Uid=`head-$Line /etc/passwd | tail -1 | cut -d: -f3`

        Shell=`head-$Line /etc/passwd | tail -1 | cut -d: -f7`


        echo"User: $UserName, UID is $Uid, Shell: $shell"

done



练习7:写一个脚本

     显示/etc/passwd文件中第1、3、6、12个用户的用户名、ID和基本组的组名;

#!/bin/bash


for Line in 1 3 6 12; do

UserName=`head -$Line /etc/passwd | tail -1 | cut -d: -f1`

Uid=`head -$Line /etc/passwd | tail -1 | cut -d: -f3`

GroupName=`id -gn $UserName`

echo "$UserName, $Uid, $GroupName"

done


列表的生成方式:

1:逐个给出,如:/etc/inittab/etc/fstab;

2:使用通配符来实现文件通配,例:for File in /var/*;

3:使用命令生成列表,详见下例(生成的一般为相对路径)

            #!/bin/bash

for File in `ls /var`;do

                  file /var/$file

done

4:生成数字序列;

    {}:{起始数字..结束数字},例如{1..100}表示从1到100之间的所有正整数

      `seq [起始数字] [步长] [结束数字]`,例:seq 1 2100 表示从1到100之间以2个单位输出


练习8: 写一个脚本

使用for循环取出每个用户用户名和Shell


#!/bin/bash

LINES=`wc -l/etc/passwd | cut -d' ' -f1`


for I in `seq 1$LINES`; do

 head -$I /etc/passwd | tail -1 | cut -d:-f1,7

done



本文转自 z永 51CTO博客,原文链接:http://blog.51cto.com/pangge/1253992


上一篇:LoadRunner脚本编写之一


下一篇:【BBED】使用bbed修改字符类型数据