zoukankan      html  css  js  c++  java
  • 【转】shell学习笔记(六)——流程控制之for循环

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

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

    1. for((i=1;i<</span>=10;i++));do echo $(expr $i 4);done 
    2. 在shell中常用的是 for in $(seq 10) 
    3. for in `ls` 
    4. for in ${arr[@]}  
    5. for 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 in f1 f2 f3 ;do 
    12. echo $i 
    13. done 
    14. echo 
    15. echo "C 语法for 循环:" 
    16. for (( i=0i<</span>10i++)); 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 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 in `seq 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 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 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     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 in           字符串列表A  
    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 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 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 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 
    3.         for 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 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 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 in $LIST; do          
    4.   mount /backup/$d 
    5.   rsync -ax --exclude fstab --delete /$d/ /backup/$d/ 
    6.   umount /backup/$d 
    7. done
  • 相关阅读:
    活脑筋的相信机会!
    亿万富翁巴菲特的理财习惯大揭秘
    让你的创业失败的18个昏招 都归结到这里
    创业成功的基础:时间管理
    三个故事的启发
    张瑞敏:借来的火点不亮自己的心灵
    李嘉诚谈管理艺术:想当老板还是领袖
    高燃:“80后人精儿”是这样炼成的
    比尔盖茨的11条人生箴言(英汉对照)
    笔者认为,中国的互联网行业需要真正的CEO
  • 原文地址:https://www.cnblogs.com/xiongyunqi/p/3735837.html
Copyright © 2011-2022 走看看