使用getent passwd |grep "/bin/bash"|awk -F: '{print $1}'
获取可登录root信息。
将输出赋值给 UserList
变量
[root@localhost ~]# getent passwd |grep "/bin/bash"|awk -F: '{print $1}'
root
media
UserList=$(getent passwd |grep "/bin/bash"|awk -F: '{print $1}')
遍历
UserList=$(getent passwd |grep "/bin/bash"|awk -F: '{print $1}')
for user in "$UserList";do
id $user
done
输出:
id: extra operand ‘media’
Try 'id --help' for more information.
原因:
因为UserList=$(getent passwd |grep “/bin/bash”|awk -F: ‘{print $1}’),将两个值赋值给了变量UserList,作为了变量UserList两个元素,在for 循环中使用 “UserList” ,会将UserList两个元素作为一个变量输出;将引号去掉,for 循环就会以空格或者制表符位分隔符,循环读取变量元素。
UserList=$(getent passwd |grep "/bin/bash"|awk -F: '{print $1}')
for user in $UserList;do
id $user
done
输出
uid=0(root) gid=0(root) groups=0(root)
uid=1000(media) gid=1000(media) groups=1000(media)
while循环如何遍历
UserList=$(getent passwd |grep "/bin/bash"|awk -F: '{print $1}')
while read user ;do
id $user
done <<< "$UserList"
将"$UserList" 所有元素传输给 while,然后在进行遍历即可。这点和 for 循环是相反的。