16_Shell语言———for循环元素列表的生成法则
for循环语句的元素列表可以由几种方式生成:a)逐一列举所有元素,前文中的元素列表都是采用的这种形式;
b)采用通配符的方式。逐一列举所有元素的方式只适合于少量元素的列表,如果元素个数较多,此方法就不适用了。
如要遍历/var 目录下的所有文件,且判断文件类型,如果采用ls /var查看所有文件,然后逐一列举所有元素的方式,会比较麻烦,但是如果采用或通配符来生成列表,会使操作简单很多:
# nano show_files_type.sh
#! /bin/bash
#
for File in /var/*; do
#如果要显示/var下所有以c开头的文件类型,可以使用/var/c*
file $File
done
unset File
———————————————执行结果——————————————
# ./show_files_type.sh
/var/account: directory
/var/cache: directory
/var/crash: directory
/var/cvs: directory
/var/db: directory
/var/empty: directory
/var/games: directory
/var/gdm: sticky directory
/var/lib: directory
/var/local: directory
/var/lock: directory
/var/log: directory
/var/mail: symbolic link to `spool/mail'
/var/nis: directory
/var/opt: directory
/var/preserve: directory
/var/run: directory
/var/spool: directory
/var/tmp: sticky directory
/var/www: directory
/var/yp: directory
c)使用命令来生成列表。
除了通配符,使用命令来生成列表同样也能起到简化代码的效果。还是上述例子,“/var/*”列表可以用ls /var命令来生成,注意使用命令生成的列表需要使用反引号来进行引用:
#!/bin/bash
#
for File in `ls /var`;do
file /var/$File
done
unset File
———————————————执行结果——————————————
# ./show_files_type.sh
/var/account: directory
/var/cache: directory
/var/crash: directory
/var/cvs: directory
/var/db: directory
/var/empty: directory
/var/games: directory
/var/gdm: sticky directory
/var/lib: directory
/var/local: directory
/var/lock: directory
/var/log: directory
/var/mail: symbolic link to `spool/mail'
/var/nis: directory
/var/opt: directory
/var/preserve: directory
/var/run: directory
/var/spool: directory
/var/tmp: sticky directory
/var/www: directory
/var/yp: directory
d)生成数字序列,其方式有:
①{起使数据..结束数据}。
例如要生成1到100个数字的元素列表,就可以写成:{1..100}
②使用seq命令。使用man seq可以查看seq的用法:
seq ... LAST#指定结束数据
seq ... FIRST LAST #指定开始和结束数据
seq ... FIRST INCREMENT LAST
#指定开始和结束数据,以及每次递增或递减的数值
如分别显示1-6,3-6以及3到16且每次间隔2
———————————————执行结果——————————————
# man seq
# seq 6
1
2
3
4
5
6
# seq 3 6
3
4
5
6
# seq 3 2 16
3
5
7
9
11
13
15
故元素列表可以使用 `seq [起始数字] [步长] [结束数字]` 的形式来生成。
下面来举个例子介绍元素列表的生成:
如果要使用for循环取出每个用户的用户名和shell,可以采用如下形式:
# nano user_shell.sh
#!/bin/bash
#
LINES=`wc -l /etc/passwd | cut -d' ' -f1`
# 声明变量LINES用来存放需要遍历的行数,因为wc -l命令会带上文件名,故需要
# 用cut命令截取第一段,即行数
for I in `seq 1 $LINES`;do
# 变量I从1开始,到LINES行结束
head -$I /etc/passwd | tail -1 | cut -d: -f1,7
# 每次head命令取出前I 行,然后通过管道传递给tail命令,
# 由tail命令取出倒数第一行,即正数第I 行,然后再通过管道传递给cut命令,
# 由cut命令以“:”进行分隔,然后截取分隔后的第1、 7小段
done
unset I
unset LINES
———————————————执行结果—————————————
# nano user_shell.sh
# chmod +x user_shell.sh
# ./user_shell.sh
root:/bin/bash
bin:/sbin/nologin
daemon:/sbin/nologin
adm:/sbin/nologin
lp:/sbin/nologin
sync:/bin/sync
shutdown:/sbin/shutdown
halt:/sbin/halt
mail:/sbin/nologin
uucp:/sbin/nologin
operator:/sbin/nologin
games:/sbin/nologin
gopher:/sbin/nologin
ftp:/sbin/nologin
nobody:/sbin/nologin
dbus:/sbin/nologin
usbmuxd:/sbin/nologin
vcsa:/sbin/nologin
rpc:/sbin/nologin
rtkit:/sbin/nologin
avahi-autoipd:/sbin/nologin
abrt:/sbin/nologin
rpcuser:/sbin/nologin
nfsnobody:/sbin/nologin
haldaemon:/sbin/nologin
gdm:/sbin/nologin
ntp:/sbin/nologin
apache:/sbin/nologin
saslauth:/sbin/nologin
postfix:/sbin/nologin
pulse:/sbin/nologin
sshd:/sbin/nologin
tcpdump:/sbin/nologin
centos:/bin/bash
hbase:/bin/bash
openstack:/bin/bash
hadoop:/bin/bash
ubuntu:/bin/bash
debian:/bin/bash
gentoo:/bin/bash
slackware:/bin/bash
archlinux:/bin/bash
sysuser:/bin/bash
sysuser1:/bin/bash
bsd:/bin/csh
moregrp:/bin/bash
redis:/bin/bash
mandriva:/bin/bash
fedora:/bin/csh
suse:/bin/dash
tom:/bin/bash
nologin:/sbin/nologin
mysql:/sbin/nologin
user2:/bin/bash
user3:/bin/bash
userA:/bin/bash
userB:/bin/bash
userC:/bin/bash
页:
[1]