shell中的for循環用法詳解


for 命令:
for i in 的各種用法 :

  • for i in "file1" “file2” “file3”
  • for i in /boot/*
  • for i in /etc/*.conf
  • for i in $(seq -w 10) --》等寬的01-10
  • for i in {1..10}
  • for i in $( ls )
  • for I in $(< file)
  • for i in "$@" --》取所有位置參數,可簡寫為for i
    注意:bash shell支持C式for循環
#!/bin/bash
j=$1
for ((i=1; i<=j; i++))
do
touch file$i && echo file $i is ok
done

復習

  • $@: 所有位置變量的內容
  • $#: 位置變量的個數
  • $0: 文件名
  • $*: 所有位置變量的內容

編寫腳本應該注意的事項:

  1. 開頭指定使用什么shell,例如:bash,ksh,csh等
  2. 腳本功能描述,使用方法,作者,版本,日期等
  3. 變量名,函數名要有實際意義,函數名以動名詞形式,第二個單詞首字母要大寫。例如:updateConfig()
  4. 縮進統一用4個空格,不用TAB
  5. 取變量值使用大括號,如${varname}
  6. 刪除文件時,如果路徑有變量的,要判斷變量有值,如rm -f ${abc}/*
    如果變量abc沒有值,則會把根目錄下的文件刪除
  7. 腳本中盡量不要使用cd變換目錄
  8. 函數中也要有功能描述,使用依法,版本,日期等
  9. 函數的功能要單一,不要太復雜
  10. $()比` `更好
  11. 盡量不要使用多層if語句,而應該以case語句替代
  12. 如果需要執行確定次數的循環,應該用for語句替代while語句
  13. 輸入的參數要有正確性判斷
  14. 多加注釋,方便自己或他人閱讀。

練習1:編寫腳本清空所有arp緩存記錄:

#!/bin/bash
for i in $(arp | tail -n +2|tr -s ' ' |cut -d' ' -f1)
do
    arp -d $i
done

練習2:產生十個隨機數:
方法1:

#for i in {0..9};do echo $RANDOM;done

方法2:

#for i in $(seq 10);do echo $RANDOM;done

練習3:倒數五秒:

#!/bin/bash
echo "准備倒數5秒:"
for i in $(seq 5 -1 1)
do
    echo -en "$i";sleep 1
done
echo -e "開始"

方法2:

#!/bin/bash
echo "准備倒數5秒:"
for i in $(seq 5 -1 1)
do
    echo -en "\b$i";sleep 1
done
echo -e "\b開始"

練習4:批量添加用戶:

#!/bin/bash
for i in $(cat /root/users.txt)        --》從列表文件讀取文件名
do
    useradd $i
    echo "123456" | passwd --stdin $i --》通過管道指定密碼字串
done

練習:
查找出uid大於10000的用戶,然后刪除,必須使用for循環。

#/bin/bash
u_uid=(`cat /etc/passwd | awk -F: '{print $3}'`)
u_name=(`cat /etc/passwd | awk -F: '{print $1}'`)
for i in  `seq ${#u_uid[@] }`
do
    if ((  ${u_uid[i-1]} > 10000  ))
    then
           userdel -r  ${u_name[i-1]}&&echo "${u_name[i-1]} delete ok"
    fi
done

方法2:用正則找出大於10000的用戶:

#cat /etc/passwd | egrep “1[0-9]{4} | [2-9]{5,}”

例子:根據ip地址檢查網絡中存活的主機ip。

這里寫圖片描述

break語句:(跳出循環)

  • 在for、while、until等循環語句中,用於跳出當前所在的循環體,執行循環體后的語句

continue語句:(跳出本次循環)

  • 在for、while、until等循環語句中,用於跳出循環體內余下的語句,重新判斷條件以便執行下一次循環。

練習:使用for循環實現批量添加用戶

#!/bin/bash
for i in $(cat /root/users.txt) --》從列表文件讀取文件名
do   
    useradd $i
    echo “123456”| passwd $i --stdin   --》通過管道指定密碼UNAME
done

(ps:判斷用戶是否存在:id命令)

位置變量

  • 位置變量:$n ,但是大於9的位置參數要用{}括起來:${10}
  • 位置變量的作用:其實就是傳遞參數到腳本里
  • $0 --》代表的是腳本自己的名字

(位置變量的最常用用法:bash 1.sh 變量1 變量2...)

預定義變量:

  • $#:命令行中位置變量的個數
  • $*:所有位置變量的內容(較少使用)
  • $@:所有位置變量的內容
  • $0:當前執行的進程/程序名
  • $$ :當前shell的PID值, echo $$; ps $$, 常用作臨時變量的后綴
  • $?:上一條命令執行后返回的狀態,當返回狀態值為0時表示執行正常,非0值表示執行異常或出錯
  • $RANDOM :隨機數,可以作為臨時文件名

例:輸出0-9以內的隨機數--》echo $((RANDOM%10))
輸出1-10以內的隨機數--》echo $((RANDOM%10+1))

  • !$:代表上一條命令的參數
  • !!:執行上一條命令

練習: 輸出
$1 is aa,
$2 is bb,
$3 is cc,
$4 is dd,
$5 is ee
答案:

#!/bin/bash

echo "there are $# arguments in this scripts"
N=1  --》變量N用來計數  
for i in $@
do
    echo "\$$N is $i"
    ((N++))
done

PS:
ping 命令

  • -c 1 ---》只ping一次。
  • -i 0.2--》第一個包和第二個包之間間隔0.2s
  • -w 2 --》只等待2s

例:
ping 172.30.132.123 &>/dev/null
重定向對於ping命令無用,執行成功$?就返回0,不成功則返回1

根據IP地址檢查網絡中存活的主機IP(大范圍的掃描)

#!/bin/bash
for r in 192.168.1.{1..254}
do
    ping -c1 -w1 "${ip}" &>/dev/null
done
arp -n|grep ether|tr -s ' '|cut -d' ' -f1

關於ping命令的一個最經典的腳本:

for i in {1..193}
do
    ( ping -c1 -i0.2 -w1 172.16.30.$i &>/dev/null
    if ((  $?==0  ))
    then
            echo "172.16.30.$i up"    >>2.txt
    else
            echo "172.16.30.$i down"    >>3.txt
    fi )&    --》這樣就把這一段放到后台去執行了,大大加快了速度。
done
sleep 2
live_pc_num=`cat 2.txt|wc -l`
down_pc_num=`cat 3.txt|wc -l`
echo "there are $down_pc_num is down"
echo "there are $live_pc_num is up"
echo "list:"
cat 2.txt
rm -rf 2.txt 3.txt

break語句

典型的while循環:

#!/bin/bash
i=1
while :    --》:等價為true
do
        echo "$i"
        ((i++))
        sleep 0.3
done
注:這是個死循環,會一直執行下去

加上break,可以跳出循環

#!/bin/bash
i=1
while :
do
        echo "$i"
        ((  i++  ))
        if ((   i==20000  ))  --》輸出的只有1-19999
        then
                break
        fi
done

小結

  • break:跳出整個循環
  • exit:跳出腳本
  • continue:跳出本次循環,接着執行下一次循環

案例練習9:
批量添加用戶並且滿足以下要求:

這里寫圖片描述

答案:

#!/bin/bash
read -p "請輸入用戶名的前綴:" a 
read -p "請輸入用戶的數目:" num
if (( $num<=10 ))
then
        n=0
        for i in `seq $num`
        do
               if useradd $a$i &>/dev/null
                then
                        echo "用戶$a$i創建成功!"
                        (( n++ ))
                        echo "123456"|passwd $a$i --stdin &>/dev/null
                fi
        done
        echo "一共創建的用戶數:$n個"
else
        echo "最多只能創建10個用戶啦!"
fi


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM