for循环语句的元素列表可以由几种方式生成:
a)逐一列举所有元素,前文中的元素列表都是采用的这种形式;
b)采用通配符的方式。逐一列举所有元素的方式只适合于少量元素的列表,如果元素个数较多,此方法就不适用了。
如要遍历/var 目录下的所有文件,且判断文件类型,如果采用ls /var查看所有文件,然后逐一列举所有元素的方式,会比较麻烦,但是如果采用或通配符来生成列表,会使操作简单很多:
# nano show_files_type.sh
#! /bin/bash# for File in /var/*; do#如果要显示/var下所有以c开头的文件类型,可以使用/var/c*file $Filedoneunset File
———————————————执行结果——————————————
[root@localhost ~]# ./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`;dofile /var/$Filedoneunset File
———————————————执行结果——————————————
[root@localhost ~]# ./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 [OPTION]... LAST #指定结束数据 seq [OPTION]... FIRST LAST #指定开始和结束数据 seq [OPTION]... FIRST INCREMENT LAST #指定开始和结束数据,以及每次递增或递减的数值
如分别显示1-6,3-6以及3到16且每次间隔2
———————————————执行结果——————————————
[root@localhost ~]# man seq[root@localhost ~]# seq 6123456[root@localhost ~]# seq 3 63456[root@localhost ~]# seq 3 2 163579111315
故元素列表可以使用 `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小段doneunset Iunset LINES
———————————————执行结果—————————————
[root@localhost ~]# nano user_shell.sh[root@localhost ~]# chmod +x user_shell.sh[root@localhost ~]# ./user_shell.shroot:/bin/bashbin:/sbin/nologindaemon:/sbin/nologinadm:/sbin/nologinlp:/sbin/nologinsync:/bin/syncshutdown:/sbin/shutdownhalt:/sbin/haltmail:/sbin/nologinuucp:/sbin/nologinoperator:/sbin/nologingames:/sbin/nologingopher:/sbin/nologinftp:/sbin/nologinnobody:/sbin/nologindbus:/sbin/nologinusbmuxd:/sbin/nologinvcsa:/sbin/nologinrpc:/sbin/nologinrtkit:/sbin/nologinavahi-autoipd:/sbin/nologinabrt:/sbin/nologinrpcuser:/sbin/nologinnfsnobody:/sbin/nologinhaldaemon:/sbin/nologingdm:/sbin/nologinntp:/sbin/nologinapache:/sbin/nologinsaslauth:/sbin/nologinpostfix:/sbin/nologinpulse:/sbin/nologinsshd:/sbin/nologintcpdump:/sbin/nologincentos:/bin/bashhbase:/bin/bashopenstack:/bin/bashhadoop:/bin/bashubuntu:/bin/bashdebian:/bin/bashgentoo:/bin/bashslackware:/bin/basharchlinux:/bin/bashsysuser:/bin/bashsysuser1:/bin/bashbsd:/bin/cshmoregrp:/bin/bashredis:/bin/bashmandriva:/bin/bashfedora:/bin/cshsuse:/bin/dashtom:/bin/bashnologin:/sbin/nologinmysql:/sbin/nologinuser2:/bin/bashuser3:/bin/bashuserA:/bin/bashuserB:/bin/bashuserC:/bin/bash