语法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