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
———————————————执行结果——————————————
[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`;do file /var/$File done unset 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 6 1 2 3 4 5 6 [root@localhost ~]# seq 3 6 3 4 5 6 [root@localhost ~]# 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
———————————————执行结果—————————————
[root@localhost ~]# nano user_shell.sh [root@localhost ~]# chmod +x user_shell.sh [root@localhost ~]# ./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
转载于:https://blog.51cto.com/wuyelan/1415104