在实际工作环境中,经常会遇到某项任务需要多次执行的情况,而每次执行时仅仅是处理的对象不一样,其他命令完全相同。如:根据服务器清单检查各个主机的存活状态;根据ip地址黑名单设置拒绝访问的防火墙策略等。

这样繁琐的重复任务时,if语句已经不能满足需求。则我们需要for循环语句。


For语句的结构

使用for循环时,需要指定一个变量及可能的取值列表,针对每一个不同的取值重复执行相同的命令序列,直到变量值用完退出循环。在这里,“取值列表”称为for语句的执行条件,其中包括多个属性相同的对象,需要预先指定(如上面提到的ip黑名单)。

for 变量名 in 取值列表

do

命令序列

done

for语句的操作对象为用户指定的变量,并通过in关键字为该变量预先设置了一个取值列表,多个取值之间以空格进行分隔。位于do。。。。。done之间的命令序列称为“循环体”,其中的执行语句需要引用变量以完成相对的任务。

For语句的执行流程:首先将列表中的第一个取值赋予给变量,并执行do。。。。done循环体中的命令序列。然后将列表中的第二个取值赋值给变量,并执行循环体中的命令序列。。。。。。依次类推,直到列表中的所有取值用完,然后将跳至done语句,表示循环结束。


事例1:

根据姓名列表批量添加用户:根据员工列表,在Linux服务器中添加相应的用户账号。初始密码为123456.

#vi adduser.sh

#!/bin/bash

ULIST=$(cat /root/users.txt)

for UNAME in $ULIST

do

useradd $UNAME

echo “123456” | passwd --stdin KaTeX parse error: Expected 'EOF', got '&' at position 7: UNAME &̲>/dev/null don…(cat /root/iplist.txt)

for IP in $HLIST

do

ping -c 3 $IP &> /dev/null

if [ $? -eq 0 ]

then

echo “host $IP is up”

else

echo “host $IP is down”

fi

done

脚本中的iplist是ip地址文件。

for循环语句#yyds干货盘点#_for语句

事例3:批量添加用户

#!/bin/bash

#本脚本用来批量创建系统用户

echo ‘成功创建用户:’ > /root/user_name

read -ep ‘请输入要创建的用户数量:’ num

for i in seq 1 $num

do

Grep(筛选)" user-$i" /etc/passwd > /dev/null 2>&1

if [ ? − n e 0 ] ; t h e n u s e r a d d u s e r − ? -ne 0 ]; then useradd user-?−ne0];thenuseradduser−i > /dev/null 2>&1

if [ ? − e q 0 ] ; t h e n e c h o " u s e r − ? -eq 0 ]; then echo "user-?−eq0];thenecho"user−i" >> /root/user_name

echo "user-i " ∣ p a s s w d u s e r − i"| passwd user-i"∣passwduser−i --stdin > /dev/null 2>&1

echo “user-i 创 建 成 功 ! " f i e l s e e c h o " u s e r − i 创建成功!" fi else echo "user-i创建成功!"fielseecho"user−i 用户已存在,创建失败!”

fi

done

cat /root/user_name