脚本编程之循环:for,while,until

shell中的循环语句一般有:

for   while   until

一、for

    for 变量名 in 列表;do

        循环体

    done

    

    首先将in后list列表的第一个常数或字符串赋值给循环变量,

    然后执行循环体;依次赋值列表中的字段,最后执行done命令后的命令序列。

    list列表生成方式: 

        (1) 直接给出列表    1 2 3

        (2) 整数列表:

            (a) {start..end}     {1..10}

            (b) $(seq [start [step]] end)    `seq 1 10`

        (3) 返回列表的命令 $(COMMAND) 

        (4) 使用glob,如:*.sh

        (5) 变量引用; $@, $*

提示输入正整数n的值,计算1+2+3+…n的 总和

read -p "please enter a positive integer:" n
    for i in $(seq 1 $n 2>/dev/null);do
        let s+=i
    done
done
echo "sum=$s"

   特殊用法:类似C语言for

    for ((控制变量初始化;条件判断表达式;控制变量的修正表达式)) 

    do

        循环体

    done 

    双小括号:实现C风格变量操作 ((i++)) 

    控制变脸初始化:仅在第一次循环时执行

    控制变量的修正表达式:会在进入下一轮循环前先执行

1到100正整数和for实现

for((i=1;i<=100;i++));do
    let sum+=i
done
echo $sum

二、while

    while CONDITION; do

        循环体

    done 

        条件为真,执行循环;

        条件为假,退出循环。

     直到不符合条件则退出循环

    CONDITION:循环控制条件;进入循环之前,先做一次判断;每次循环后再次判断;

    CONDTION变量的值应为变化的;应该在循环体不断地被修正;创造退出循环的条件

1到100内所有正整数和while实现

i=1
while [ $i -le 100 ];do
    let s=s+i
    let i++
done
echo "$s"

  特殊用法:

    while read line; do

        循环体

    done < /PATH/FROM/SOMEFILE

    依次读取文件中的每一行复制给变量line

扫描/etc/passwd文件每一行,如发现GECOS字段为空,则填 充用户名和单位电话为62985600,

并提示该用户的GECOS信 息修改成功。

while read line ;do
    user=`echo $line|cut -d: -f1`
    gc=`echo $line|cut -d: -f5`
    [ -z $gc ]&>/dev/null && usermod -c "$user 62985600" $user && printf "%-12s %s\n" $user
 "GECOS changed"
done < /etc/passwd
echo finished

三、until

    until CONDITION; do

        循环体

    done

        条件为假,执行循环

        条件为真,退出循环

    直到符合条件退出循环

1到100正整数和until实现

i=0
until [ $i -gt 100 ];do
let sum+=i
let i++
done
echo $sum

循环控制语句:

    一般结合判断语句使用,用于跳过某些指定情况

    1)continue #    #为第几层,最内层为1层 

        提前结束第#层的本轮循环,直接进入#层下一轮判断。

    2)break #    结束#层循环,最内层为1层 

        直接结束#层循环体,#层后续的循环不再执行。

作业:

1、每隔3秒钟到系统上获取已经登录的用户的信息;如果发现用户hacker登录,则将登录时间和主机记录于日志/var/log/login.log中,并提示该用户退出系统。

#!/bin/bash
#
echo
until w|cut -d ' ' -f1|grep "hacker" ;do
    let i++
    echo -e "\b\r$i \t `date` \t no hacker"
    sleep 3
done
echo "should logout"|mail -s 'warning' hacker
echo "is here ! ! !"
echo -e "`date` warning! `w|grep "^hacker"`">>/var/log/messages

2、随机生成10以内的数字,实现猜字游戏,提示比较大或小,相等则退出

#!/bin/bash
#
n=$[RANDOM%11]
num=a
until [ $num -eq $n ]&>/dev/null;do
    read -p "please enter a numbe [0-10]:" num
    if [ -z $num ] ;then
        continue 2
    elif [[ ! $num =~ 1?[0-9] ]] ;then
        continue 2
    elif [ $num -gt $n ] ;then
        echo "    your number is bigger"
    elif [ $num -lt $n ] ;then
        echo "    your number is smaller!"
    fi
done
echo you hit the number!  $n

3、编写脚本,求100以内所有正整数之和

#!/bin/bash
#zjj
i=0
until [ $i -gt 100 ];do
    let sum+=i
    let i++
done
echo $sum

4、编写脚本,通过ping命令探测172.16.250.1-254范围内的所有主机的在线状态,统计在线主机和离线主机各多少。

#!/bin/bash
#
i=1
NumUp=0
NumDown=0
echo
until [ $i -gt 254 ];do
    if ping -W1 -c1 10.1.252.$i &>/dev/null ;then
        let NumUp++
        echo -e "\n\t\t 10.1.252.$i  is up  $NumUp"
    else
        let NumDown++
        echo -e "\b\r$NumDown down"
    fi
    let i++
done

5、编写脚本,打印九九乘法表

#!/bin/bash
#
i=1
until [ $i -gt 9 ];do
    j=1
    until [ $j -gt $i ];do
        echo -n -e  "${j}*${i}=$[$i*$j]\t"
        let j++
    done
echo
let i++
done

6、编写脚本,利用变量RANDOM生成10个随机数字,输出这个10数字,并显示其中的最大者和最小者

#!/bin/bash
#zjj
i=1
ran=$RANDOM
max=$ran
min=$ran
echo $ran
until [ $i -gt 9 ];do
    ran=$RANDOM
    echo $ran
    if [ $ran -gt $max ];then
        max=$ran
    elif [ $ran -lt $min ];then
        min=$ran
    fi
    let i++
done
echo MAX=$max   MIN=$min

7、编写脚本,实现打印国际象棋棋盘

#!/bin/bash
#
i=1
row=1
until [ $row -gt 8 ] ;do
column=1
    until [ $column -gt 8 ] ;do
        i=$[$i%2]
        if [ $i -eq 1 ];then
            echo -ne "\033[47m  \033[0m"
        else
            echo -ne "\033[41m  \033[0m"
        fi
        let i++
        let column++
    done
echo
    let row++
    let i++
done

8、打印等腰三角形 (菱形)

#!/bin/bash
#
read -p "enter the number of line:" line
for((i=1;i<=$line;i++))
do
    count=$[2*$i-1]
    sapce=$[$line-$i+1]
    printf "%${sapce}c" ' '
    for((j=1;j<=$count;j++));do
        echo -n "*" 
    done
echo
done
for((i=$[line-1];i>=1;i--))
do
    count=$[2*$i-1]
    sapce=$[$line-$i+1]
    printf "%${sapce}c" ' '
    for((j=1;j<=$count;j++));do
        echo -n "*" 
    done
echo
done

9.安装centos6.7,用centos6.8kernel升级

原创文章,作者:Jasper,如若转载,请注明出处:http://www.178linux.com/36913

(0)
JasperJasper
上一篇 2016-08-18
下一篇 2016-08-18

相关推荐

  • Linux学习总结01—操作系统与硬件介绍(原创)

      在计算机中,分为以下结构,运算器,控制器,存储器,输入、输出设备,运算器和控制起的整个就形成了中央处理器(称作为CPU),而cpu的功能就是提供运算,运算的数据都是经由控制器而来,控制器其实是往主存储器中取得数据,内存中的数据是由用户来输入的,其运算的结果通过控制器存储在内存当中,之后可以根据用户的指令输出在一个设备当中(例如显示器),我们都知…

    Linux干货 2016-10-29
  • Linux计算机基础-入门2016-07-19

    Linux计算机基础-入门2016-07-19 计算机系统的组成部分 计算机系统由硬件系统和软件系统两大部分组成 硬件系统 冯.诺依曼体系结构: 1946年数学家冯.诺依曼提出运算器,控制器,存储器,输入设备,输出设备。 具体变现为一下硬件: 运算器,控制器  ——>  CPU 存储器  …

    Linux干货 2016-08-04
  • 用keepalived高可用nginx

    单主模型 环境四个虚拟机 upstream server:node1:172.16.100.6         CeotOS 6 upstream server:node3:172.16.100.69         CeotOS 7 节点1:172.16.100.67                        CeotOS 7 节点2:node2:17…

    2017-10-15
  • HAProxy服务配置

    HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件。 相较与 Nginx,HAProxy 更专注与反向代理,因此它可以支持更多的选项,更精细的控制,更多的健康状态检测机制和负载均衡算法。 四层和七层负载均衡的区别: 四层: 通过分析IP层及TCP/UDP层的流量实现的基于“IP+端口”的负载均衡。 七层: …

    Linux干货 2017-05-19
  • 初探SElinux

    SELinux介绍: SELinux: Secure Enhanced Linux(安全强化的linux),是美国国家安全局(NSA=The National Security Agency)和 SCC(Secure Computing Corporation)开发的Linux的一个强制访问控制的安全模块。2000年以GNU GPL发布,Linux内核2.6…

    Linux干货 2016-10-09
  • sed命令初识

           sed是一种流编辑器,它是文本处理中非常常用的工具,能够配合正则表达式使用。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自…

    Linux干货 2017-12-03