linux中的shell编程之for循环

语法1:

for 变量 in 值1 值2 值3...
    do
        程序语句
    done

语法2:

for ((初始值;循环控制条件;变量变化))
    do 
        程序语句
    done

实例1:循环输出1到5

#!/bin/bash

for i in 1 2 3 4 5
    do
        echo $i
    done

实例2:批量解压缩*.tar.gz文件压缩包

#!/bin/bash
# 批量解压/home/fz下的.tar.gz及.tgz压缩格式文件

cd /home/fz/
ls *.tar.gz > ls.log
ls *.tgz >> ls.log

for i in $(cat ls.log)
    do 
        tar -zxf $i &> /dev/null    # 将此命令执行的正确信息及错误信息丢到回收站中
    done
rm -rf ls.log

实例3:语法2用来求1到100的和

#!/bin/bash
# 从1加到100

s=0
for ((i=1;i<=100;i=i+1))
    do 
        s=$(($s+$i))
    done
echo "The sum of 1+2+...+100 is : $s"

实例4:批量添加和删除指定数量的用户

#!/bin/bash
# 批量添加指定数量的用户
read -p "Please input user name:" -t 30 name
read -p "Please input the number of users: " -t 30 num
read -p "Please input the password of users: " -t 30 pass
if [ ! -z "$name" -a ! -z "$num" -a ! -z "$pass" ]
    then
    y=$(echo $num | sed 's/[0-9]//g')
    if [ -z "$y" ]
        then
        for ((i=1;i<=$num;i=i+1))
            do
                /usr/sbin/useradd $name$i &> /dev/null
                echo $pass | /usr/bin/passwd --stdin $name$i &> /dev/null
            done
    fi
fi

注意如果是普通用户运行此脚本,是无法添加用户的,需要有管理员权限,如果普通用户在/etc/sudoers中增加了权限,可以采用要在执行命令之前添加sudo

具体的程序的运行结果为:

实例5:批量删除刚刚指定生成的用户

#!/bin/bash
# 删除当前系统中除了root及fz两个用户之外的所有用户
for i in $(cat /etc/passwd | grep /bin/bash | grep -v root | grep -v fz | cut -d ":" -f 1)
    do
        userdel -r $i
    done

猜你喜欢

转载自blog.csdn.net/qq_40420795/article/details/84993757