如下內容是學習菜鳥教程之shell教程,所整理的筆記php
菜鳥教程之shell教程:http://www.runoob.com/linux/linux-shell.htmlhtml
和Java、PHP等語言不同,sh的流程控制不可爲空,如(如下爲PHP流程控制寫法):linux
<?php if (isset($_GET["q"])){ search(q); } else { //不作任何事情 } #在sh/bash裏不能夠這麼寫,若是else分支沒有語句執行,就不要寫這個else.
if 語句語法格式: if condition then command1 command2 ... fi #寫成一行(適用於終端) if else 語法格式: if condition then command1 command2 ... else command fi if else-if else語法格式: if condition1 then command1 elif condition2 then command2 else commandN fi #if else語句常常與test命令結合適用,以下所示: #!/bin/bash num1=$[2*3] num2=$[1+5] if test $[num1] -eq $[num2] then echo '兩個數字相等!' else echo '兩個數字不相等!' fi
for var in item1 item2 ... itemN do command1 command2 ... command3 done 也能夠寫成一行:for var in item1 item2 ... itemN; do ocmmand1; command2... done; 注意: 當變量值在列表裏,for循環即執行一次全部命令,使用變量名獲取列表中的當前取值。命令可爲任何有效的shell命令和語句。in列表能夠包含替換、字符串和文件名。 in列表是可選的,若是不用它,for循環使用命令行的位置參數。 例如,順序輸出當前列表中的數字: for loop in 1 2 3 4 5 do echo "The value is: $loop" done #若是加上'',in則不是列表,而是變成了字符串,列表是一個個字符輸出。
while condition do command done while 循環能夠用於讀取鍵盤信息: #!/bin/bash echo '按下<CTRL-D>退出' echo -n '輸入你最喜歡的網站名:' while read FILM do echo "是的!$FILM是一個好網站" done
while: do command done 或者: while true do command done 或者: for (( ; ; ))
until 循環執行一系列命令直至條件爲 true 時中止。 until 循環與 while 循環在處理方式上恰好相反。 通常 while 循環優於 until 循環,但在某些時候—也只是極少數狀況下,until 循環更加有用。 until 語法格式: until condition do command done condition 通常爲條件表達式,若是返回值爲 false,則繼續執行循環體內的語句,不然跳出循環。
case 值 in 模式1) command1 command2 ... commandN ;; 模式2) command1 command2 ... ;; esac case工做方式如上所示。取值後面必須爲單詞in,每一模式必須以右括號結束。取值能夠爲變量或常數。匹配發現取值符合某一模式後,其間全部命令開始執行直至 ;;。 取值將檢測匹配的每個模式。一旦模式匹配,則執行完匹配模式相應命令後再也不繼續其餘模式。若是無一匹配模式,使用星號 * 捕獲該值,再執行後面的命令。 eg: echo '輸入1到4之間的數字:' echo '你輸入的數字爲:' read aNum case $aNum in 1) echo '你選擇了 1' ;; 2) echo '你選擇了 2' ;; 3) echo '你選擇了 3' ;; 4) echo '你選擇了 4' ;; *) echo '你沒有輸入1到4之間的數字' ;; esac
eg: #!/bin/bash while: do echo -n "輸入1到5之間的數字:" read aNum case $aNum in 1|2|3|4|5) echo "你輸入的數字爲 $aNum!" ;; *) echo "你輸入的數字不是1到5之間的!" continue echo "遊戲結束" ;; esac done 運行代碼發現,當輸入大於5的數字時,該例中的循環不會結束,語句 echo "遊戲結束" 永遠不會被執行。 而若是在break後面循環體內,加上一句echo 語句也不被執行!
linux shell 能夠用戶定義函數,而後在shell腳本中能夠隨便調用。shell
shell中函數的定義格式以下:bash
[ function ] funname [()] { action; [return int;] } 注意: 一、能夠帶function fun() 定義,也能夠直接fun() 定義,不帶任何參數。 二、參數返回,能夠顯示加:return 返回,若是不加,將以最後一條命令運行結果,做爲返回值。 return後跟數值n(0-255 下面的例子定義了一個函數並進行調用: #!/bin/bash demoFun(){ echo "這是個人第一個Shell函數!" } echo "-----函數開始執行-----" demoFun echo "-----函數執行完畢-----" 下面定義一個帶return語句的函數: #!/bin/bash fuunWithReturn(){ echo "這個函數會對輸入的兩個數字進行想加運算..." echo "輸入第一個數字:" read aNum echo "輸入第二個數字:" read anotheerNum echo "兩個數字分別爲$aNum 和$anotherNum!" return $(($aNum+$anotherNum)) } funWithReturn echo "輸入的兩個數字之和爲 $? !" 注意: 函數返回值在調用該函數後經過 $? 來得到。 全部函數在使用前必須定義。這意味着必須將函數放在腳本開始部分,直至shell解釋器首次發現它時,纔可使用。調用函數僅使用其函數名便可。
$# 傳遞到腳本的參數個數 $* 以一個單字符穿顯示全部向腳本傳遞的參數 $$ 腳本運行的當前進程ID號 $! 腳本運行的最後一個進程ID號 $@ 與$*相同,可是使用時要加引號,並在引號中返回每一個參數 $- 顯示shell使用的當前選項,與set命令功能相同 $? 顯示最後命令的退出狀態。0表示沒有錯誤,其餘任何值代表有錯誤 eg: #!/bin/bash funWithParam(){ echo "第一個參數爲 $1 !" echo "第二個參數爲 $2 !" echo "第十個參數爲 $10 !" echo "第十個參數爲 ${10} !" echo "第十一個參數爲 ${11} !" echo "參數總數有 $# 個!" echo "做爲一個字符串輸出全部的參數 $* !" } runWithParam 1 2 3 4 5 6 7 8 9 34 73
大多數 UNIX 系統命令從你的終端接受輸入並將所產生的輸出發送回到您的終端。一個命令一般從一個叫標準輸入的地方讀取輸入,默認狀況下,這剛好是你的終端。一樣,一個命令一般將其輸出寫入到標準輸出,默認狀況下,這也是你的終端。函數
重定向命令列表以下:oop
command > file 將輸出重定向到file command < file 將輸入重定向到file command >> file 將輸出以追加的方式重定向到file n > file 將文件描述符爲n的文件以追加的方式重定向到file n >& m 將輸出文件m and n合併 n <& m 將輸入文件m and n合併 << tag 將開始標記tag和結束標記tag之間的內容做爲輸入 注意: 須要注意的是文件描述符 0 一般是標準輸入(STDIN),1 是標準輸出(STDOUT),2 是標準錯誤輸出(STDERR)。
輸出重定向詳細: mkdir users who > users cat users 輸出重定向會覆蓋文件內容,請看下面例子: echo "www.baidu.com" > users cat users www.baidu.com #只有這一行內容了 若是不但願文件內容被覆蓋,可使用>>追加到文件末尾,例如: echo "www.google.com" >> users cat users www.baidu.com www.google.com
command < file1 原本須要從鍵盤獲取輸入的命令會轉移到文件讀取內容 注意:輸出重定向是大於號(>),輸入重定向是小於號(<)。 eg: wc -l users #output:2 users wc -l < users #output:2 注意:上面兩個例子的結果不一樣:第一個例子,會輸出文件名;第二個不會,由於它僅僅知道從標準輸入讀取內容。 command1 < infile > outfile 同時替換輸入和輸出,執行command1,從文件infile讀取內容,而後將輸出寫入到outfile中。
通常狀況下,每一個unix/linux命令運行是都會打開三個文件: 標準輸入文件(stdin):stdin的文件描述符爲0,Unix程序默認從stdin讀取數據。 標準輸出文件(stdout):stdout 的文件描述符爲1,Unix程序默認向stdout輸出數據。 標準錯誤文件(stderr):stderr的文件描述符爲2,Unix程序會向stderr流中寫入錯誤信息。 默認狀況下,command > file 將 stdout 重定向到 file,command < file 將stdin 重定向到 file。 若是但願 stderr 重定向到 file,能夠這樣寫: command 2 > file command 2 >> file # stderr追加到file文件末尾 command > file 2>&1 # 將stdout 和 stderr合併後重定向到file command < file1 > file2 #對stdin 和 stdout 都重定向,command 命令將 stdin 重定向到 file1,將 stdout 重定向到 file2。
command << delimiter document delimiter 它的做用是將兩個delimiter之間的內容(document)做爲輸入傳遞給command. 注意: 結尾的delimiter 必定要頂格寫,前面不能有任何字符,後面也不能有任何字符,包括空格和 tab 縮進。 開始的delimiter先後的空格會被忽略掉。 eg: 在命令行中經過wc-l 命令計算Here Doucument 的行數: wc -l << EOF test test! www.google.com EOF #output:3 EOF就是delimiter的一種寫法 也能夠將Here Document用在腳本中: #!/bin/bash cat << EOF 歡迎來到 菜鳥教程 www.ruunoob.com EOF
command > /dev/null /dev/null是一個特殊的文件,寫入到它的內容都會被丟棄;若是嘗試從該文件讀取內容,那麼什麼也讀不到。可是 /dev/null 文件很是有用,將命令的輸出重定向到它,會起到"禁止輸出"的效果。 若是但願屏蔽 stdout 和 stderr,能夠這樣寫: command > /dev/null 2>&1 注意:0 是標準輸入(STDIN),1 是標準輸出(STDOUT),2 是標準錯誤輸出(STDERR)。
和其餘語言同樣,Shell 也能夠包含外部腳本。這樣能夠很方便的封裝一些公用的代碼做爲一個獨立的文件。學習
Shell 文件包含的語法格式以下:測試
. filename #注意點好(.)和文件名中間有一空格 or source filename eg: 建立兩個shell腳本文件 test1.sh代碼以下: #!/bin/bash url="http://www.runoob.com" test1.sh代碼以下: #!/bin/bash . ./test1.sh echo "菜鳥教程官網地址:$url"
在菜鳥教程上面學習的Shell script是基礎的。如何組合利用,還須要進一步學習。網站