博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】shell学习笔记(六)——流程控制之for循环
阅读量:4992 次
发布时间:2019-06-12

本文共 3957 字,大约阅读时间需要 13 分钟。

基本语法格式:
for 变量 in 列表
do
命令行(通常用到循环变量)
done

********Linux Shell for循环写法总结********

  1. for((i=1;i<</span>=10;i++));do echo $(expr $i \* 4);done 
  2. 在shell中常用的是 for i in $(seq 10) 
  3. for i in `ls` 
  4. for i in ${arr[@]}  
  5. for i in $* ; do 
  6. for File in /proc/sys/net/ipv4/confaccept_redirects:' 
  7. for File in /proc/sys/net/ipv4/conf/*/accept_redirects; do 
  8. echo $File 
  9. done 
  10. echo "直接指定循环内容" 
  11. for i in f1 f2 f3 ;do 
  12. echo $i 
  13. done 
  14. echo 
  15. echo "C 语法for 循环:" 
  16. for (( i=0; i<</span>10; i++)); do 
  17. echo $i 
  18. done 
---------------------------------------------------------------------------------------------------------
 
shell中for循环用法实例
实例一:几个不同的方法来实现输出1-100间可以被3整除的数
1.用(())
  1. #!/bin/bash 
  2. clear 
  3. for((i=1;i<</span>100;i++)) 
  4. for 
  5. do 
  6. if((i%3==0)) 
  7. then 
  8. echo $i 
  9. continue 
  10. fi 
  11. done 
2.使用`seq 100`
  1. #!/bin/bash 
  2. clear 
  3.  
  4. for i in `seq 100` 
  5. do 
  6. if((i%3==0)) 
  7. then 
  8. echo $i 
  9. continue 
  10. fi 
  11. done 
3.使用while
  1. #!/bin/bash 
  2. clear 
  3.  
  4. i=1 
  5. while(($i<</span>100)) 
  6. do 
  7. if(($i%3==0)) 
  8. then 
  9. echo $i 
  10. fi 
  11. i=$(($i+1)) 
  12. done 
--------------------------------------------------------------------------------------------------------
实例二:shell用for循环做数字递增法:
1.使用(())
  1. for((i=1;i<</span>10000000;i++));do 
  2.  
  3. echo $i 
  4.  
  5. done 
2.使用seq
  1. for i in `seq 1 1000000`;do 
  2.  
  3. echo $i 
  4.  
  5. done 
用seq 1 10000000做递增,之前用这种方法的时候没遇到问题,因为之前的i根本就没用到百万(1000000),因为项目需要我这个数字远大于百万,发现用seq 数值到 1000000时转换为1e+06,根本无法作为数字进行其他运算,或者将$i有效、正确的取用,遂求其他方法解决,如下
3.使用while
  1. i=1 
  2.  
  3. while(($i<</span>10000000));do 
  4.  
  5. echo $i 
  6.  
  7. i=`expr $i + 1` 
  8.  
  9. done 
因为本方法调用expr故运行速度会比第1,第2种慢不少不过可稍作改进,将i=`expr $i + 1`改为i=$(($i+1))即可稍作速度的提升,不过具体得看相应shell环境是否支持
 
4.使用{}
  1. for i in {1..10000000};do 
  2.  
  3. echo $i 
  4.  
  5. done 
其实选用哪种方法具体还是得由相应的shell环境的支持,达到预期的效果,再考虑速度方面的问题。
[root@mail mnt]# ll
-rw-r--r--  1 root root       0 Mar 28 14:24 test.20130326
-rw-r--r--  1 root root       0 Mar 28 14:24 test.20130327
-rw-r--r--  1 root root       0 Mar 28 14:24 test.20130328
-rw-r--r--  1 root root       0 Mar 28 14:24 test.20130329
  1. #!/bin/bash 
  2. D=`date +%Y%m%d` 
  3. for A in `ls | grep $D` 
  4. do 
  5. echo "$A" 
[root@mail mnt]# ./aa.sh 
test.20130328
done
补充:

 for in 循环详解

----for in 格式----
简单的字符串枚举遍历,利用for in格式对字符串按空格切分的功能
  1. for 无$变量 in 字符串 
  2. do 
  3.   $变量 
  4. done 
 例1:
  1. SERVICES="80   22   25   110   8000   23   20   21   3306   " 
  2.  
  3. for   x   in   $SERVICES     
  4.   do      
  5.   iptables   -A   INPUT   -p   tcp   --dport   $x   -m   state   --state   NEW   -j   ACCEPT      
  6.   done 
-------for variable in values--------------字符串数组依次赋值
  1. #!/bin/sh 
  2. for i in a b c           字符串列表A B C  
  3.          字符串用空格分隔,没有括号,没有逗号, 然后循环将其依次赋给变量i 
  4.          变量没有$ 
  5. do 
  6. echo "i is $i" 
  7. done  
[macg@machome ~]$ sh test.sh
i is a
i is b
i is c
-------for in 里,变量和*不等价-------
  1. #!/bin/bash 
  2. for i in *.h ; 
  3. do 
  4. cat ${i}.h 
  5. done  
[macg@vm test]$ ./tip.sh
cat: *.h.h: No such file or directory 
$i代表的是整个路径,而不是*.h里的.h前面的部分
改正
 
  1. #!/bin/bash 
  2. for i in *.h 
  3. do 
  4. cat $i 
  5. done   
[macg@vm test]$ echo hahaha >>1.h
[macg@vm test]$ echo ha >>2.h
 
[macg@vm test]$ ./tip.sh
hahaha
ha    
例2:
  1. for i in /etc/profile.d/*.sh  
  2. do 
  3.   $i 
  4. done  
 $i代表的是/etc/profile.d/color.sh,
/etc/profile.d/alias.sh, /etc/profile.d/default.sh
-------for in 对(命令行,函数)参数遍历-------
  1. test() 
  2.         local i 
  3.         for i in $* ; do 
  4.              echo "i is $i" 
  5.         done 
$*是字符串:以"参数1 参数2 ... " 形式保存所有参数 ;
$i是变量i的应用表示
[macg@machome ~]$ sh test.sh p1 p2 p3 p4
 
i is p1
i is p2
i is p3
i is p4 
 
 
------- for in语句与通配符*合用,批量处理文件-------
    批量改文件名
[root@vm testtip]# ls
aaa.txt  ccc.txt  eee.txt  ggg.txt  hhh.txt  jjj.txt  lll.txt  nnn.txt
bbb.txt  ddd.txt  fff.txt  go.sh    iii.txt  kkk.txt  mmm.txt  ooo.txt
[root@vm testtip]# cat go.sh
 
  1. for i in *.txt                 *.txt相当于一个字符串数组,依次循环赋值给i 
  2. do 
  3. mv "$i" "$i.bak"        
  4. done 
[root@vm testtip]# sh go.sh
 
[root@vm testtip]# ls
aaa.txt.bak  ccc.txt.bak  eee.txt.bak  ggg.txt.bak  hhh.txt.bak  jjj.txt.bak  lll.txt.bak  nnn.txt.bak bbb.txt.bak  ddd.txt.bak  fff.txt.bak  go.sh        iii.txt.bak  kkk.txt.bak  mmm.txt.bak  ooo.txt.bak
 
-------for in语句与` `和$( )合用,利用` `或$( )的将多行合为一行的缺陷,实际是合为一个字符串数组-------
 
  1. for i in $(ls *.txt)         
  2. do 
  3. echo $i 
  4. done 
[macg@machome ~]$ sh test
111-tmp.txt
111.txt
22.txt
33.txt
或者说,利用for in克服` `和$( ) 的多行合为一行的缺陷
 
 
-------利用for in 自动对字符串按空格遍历的特性,对多个目录遍历-------
 
  1. LIST="rootfs usr data data2" 
  2.     
  3. for d in $LIST; do          
  4.   mount /backup/$d 
  5.   rsync -ax --exclude fstab --delete /$d/ /backup/$d/ 
  6.   umount /backup/$d 
  7. done

转载于:https://www.cnblogs.com/xiongyunqi/p/3735837.html

你可能感兴趣的文章
Python 学习笔记之——用 sklearn 对数据进行预处理
查看>>
0 window DOS窗口常用指令
查看>>
c++11特性与cocos2d-x 3.0之std::bind与std::function
查看>>
ARC078 D.Fennec VS. Snuke(树上博弈)
查看>>
VIM学习笔记一
查看>>
面向对象第四单元总结
查看>>
同源策略,Jsonp实现跨域
查看>>
二叉搜索树的后序遍历序列
查看>>
纯C#的ini格式配置文件读写
查看>>
每日分享
查看>>
【干货】大数据框架整理
查看>>
年轻人,能用钱解决的,绝不要花时间(转)
查看>>
python2.7.X 升级至Python3.6.X
查看>>
VS调试方法
查看>>
jquery拖拽实现UI设计组件
查看>>
javamail模拟邮箱功能获取邮件内容-中级实战篇【内容|附件下载方法】(javamail API电子邮件实例)...
查看>>
白话排序算法--冒泡排序
查看>>
imx6 18bit display
查看>>
Spring静态属性注入
查看>>
实验10:指针2
查看>>