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

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值