歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> SHELL編程

Bourne shell編程入門及腳本測試

  ***************************************************************************** 本文由正泰Linux http://linux-down.kmip.net 搜集,整理,如需轉載,請注明出處! 本站有大量的linux電子教程,軟件,技術文檔,歡迎大家訪問!站長阿泰QQ:253222170 ****************************************************************************** 標 題: LINUX選修課講義:Bourne Shell及shell編程(1) 發信站: 碧海青天 (Wed Apr 21 23:41:45 1999), 轉信 版權聲明: 本文內容為大連理工大學LINUX選修課講義,歡迎大家轉載,但禁止使用本材料進行 任何商業性或贏利性活動。轉載時請保留本版權聲明。 作者:何斌武,[email protected],大連理工大學網絡中心,April 1999. URL: FTP://ftp.dlut.edu.cn/pub/PEOPLE/albin/ /********抱歉,為了格式不亂,我就用代碼模式粘貼了*********/ 源碼:-------------------------------------------------------------------------------- ------------------------------------------------------------------------------ Bourne Shell 介紹:Bourne Shell 基礎及其他很多有用的特性,shell編程及組織。 主要內容: .shell基礎 基本介紹,環境,選項,特殊字符 .shell變量 用戶定義變量,環境變量,位置變量(shell 參數) .shell script編程 條件測試,循環及重復控制 .shell定制 1.shell基礎知識 作者:Stephen Bourne 在Bell實驗室開發 建議:man sh 查看相關UNIX上的改進或特性 (1)shell提示符及其環境 /etc/passwd文件 提示符:$ /etc/profile $HOME/.profile (2)shell執行選項 -n 測試shell script語法結構,只讀取shell script但不執行 -x 進入跟蹤方式,顯示所執行的每一條命令,用於調度 -a Tag all variables for eXPort -c "string" 從strings中讀取命令 -e 非交互方式 -f 關閉shell文件名產生功能 -h locate and remember functions as defind -i 交互方式 -k 從環境變量中讀取命令的參數 -r 限制方式 -s 從標准輸入讀取命令 -t 執行命令後退出(shell exits) -u 在替換中如使用未定義變量為錯誤 -v verbose,顯示shell輸入行 這些選項可以聯合使用,但有些顯然相互沖突,如-e和-i. (3)受限制shell(Restircted Shell) sh -r 或 /bin/rsh 不能執行如下操作:cd, 更改PATH,指定全路徑名,輸出重定向,因此可以提供一個較 好的控制和安全機制。通常rsh用於應用型用戶及撥號用戶,這些用戶通常是看不到提 示符的。通常受限制用戶的主目錄是不可寫的。 不足:如果用戶可以調用sh,則rsh的限制將不在起作用,事實上如果用戶在vi及more


程序中調用shell,而這時rsh的限制將不再起作用。 (4)用set改變 shell選項 用戶可以在$提示符下用set命令來設置或取消shell的選項。使用-設置選項,+取消相應 選項,大多數UNIX系統允許a,e,f,h,k,n,u,v和x的開關設置/取消。 set -xv 啟動跟蹤方式;顯示所有的命令及替換,同樣顯示輸入。 set -tu 關閉在替換時對未定義變量的檢查。 使用echo $-顯示所有已設置的shell選項。 (5)用戶啟動文件 .profile PATH=$PATH:/usr/loacl/bin; export PATH (6)shell環境變量 CDPATH 用於cd命令的查找路徑 HOME /etc/passwd文件中列出的用戶主目錄 IFS Internal Field Separator,默認為空格,tab及換行符 MAIL /var/mail/$USERNAME mail等程序使用 PATH PS1,PS2 默認提示符($)及換行提示符(> ) TERM 終端類型,常用的有vt100,ansi,vt200,xterm等 示例:$PS1="test:";export PS1 test: PS1="\\$";export PS1 $echo $MAIL /var/mail/username (7)保留字符及其含義 $ shell變量名的開始,如$var 管道,將標准輸出轉到下一個命令的標准輸入 # 注釋開始 & 在後台執行一個進程 ? 匹配一個字符 * 匹配0到多個字符(與DOS不同,可在文件名中間使用,並且含.) $- 使用set及執行時傳遞給shell的標志位 $! 最後一個子進程的進程號 $# 傳遞給shell script的參數個數 $* 傳遞給shell script的參數 $@ 所有參數,個別的用雙引號括起來 $? 上一個命令的返回代碼 $0 當前shell的名字 $n (n:1-) 位置參數 $$ 進程標識號(Process Identifier Number, PID) >file 輸出重定向 <file 輸入重定向 `command` 命令替換,如 filename=`basename /usr/local/bin/tcsh` >>fiile 輸出重定向,append 轉義符及單引號: $echo "$HOME $PATH" /home/hbwork /opt/kde/bin:/usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin: $echo '$HOME $PATH' $HOME $PATH $echo \\$HOME $PATH $HOME /opt/kde/bin:/usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin:/home/hbw ork/bin 其他: $dir=ls $$dir $alias dir ls $dir ls > filelist ls >> filelist wc -l < filelist wc -l filelist sleep 5; echo 5 seconds reaches; ls -l ps ax egrep inetd find / -name core -exec rm {} \\; & filename=`date "+%Y%m%d"`.log 2. shell變量 變量:代表某些值的符號,如$HOME,cd命令查找$HOME,在計算機語言中可以使用變量可以 進行多種運算和控制。 Bourne Shell有如下四種變量: .用戶自定義變量 .位置變量即 shell script之參數 .預定義變量(特殊變量) .環境變量(參考shell定制部分) (1)用戶自定義變量(數據的存儲) $ COUNT=1 $ NAME="He Binwu" 技巧:因為大部分UNIX命令使用小寫字符,因此在shell編程中通常使用全大寫變量, 當然這並不是強制性的,但使用大寫字符可以在編程中方便地識別變量。 變量的調用:在變量前加$ $ echo $HOME /home/hbwork $ WEEK=Satur $ echo Today is $WEEKday Today is $echo Today is ${WEEK}day Today is Saturday Shell變量賦值從右從左進行(Linux Shell/bash從左向右賦值!) $ X=$Y Y=y $ echo $X y $ Z=z Y=$Z $ echo $Y $ 使用unset命令刪除變量的賦值 $ Z=hello $ echo $Z hello $ unset Z $ echo $Z $ 有條件的命令替換 在Bourne Shell中可以使變量替換在特定條件下執行,即有條件的環境變量替換。

這種變量替換總是用大括號括起來的。 .設置變量的默認值 在變量未賦值之前其值為空。Bourne Shell允許對變量設置默認值,其格式如 下: ${variable:-defaultvalue} 例: $ echo Hello $UNAME Hello $ echo Hello ${UNAME:-there} Hello there $ echo $UNAME #變量值並未發生變化 $ UNAME=hbwork $ echo Hello ${UNAME:-there} Hello hbwork $ .另一種情況:改變變量的值,格式如下: ${variable:=value} 例: $ echo Hello $UNAME Hello $ echo Hello ${UNAME:=there} Hello there $ echo $UNAME #變量值並未發生變化 there $ .變量替換中使用命令替換 $USERDIR=${$MYDIR:-`pwd`} .在變量已賦值時進行替換 ${variable:+value} .帶有錯誤檢查的有條件變量替換 ${variable:?value} 例: $ UNAME= $ echo ${UNAME:?"UNAME has not been set"} UNAME: UNAME has not been set $ echo ${UNAME:?} UNAME: parameter null or not set (2)位置變量(Shell參數) 在shell script中位置參數可用$1..$9表示,$0表示內容通常為當前執行程序的文件名。 .防止變量值被替換 readonly variable .使用export命令輸出變量,使得變量對子shell可用,當shell執行一下程序時,shell 將為其設置一個新的環境讓其執行,這稱之了subshell. 在Bourne Shell中變量通常 被認為是本地變量,也就是說在對其賦值之外的shell環境之外是不認識此變量的。使 用export對subshell可用。 例:對變量PS1的export操作,shell的提示符將發生變化。 $ PS1=`hostname`$ peony$sh $ echo $PS1 $ <-輸出結果 $ exit peony$export PS1 peony$sh peony$ echo $PS1 peony$ <-輸出結果 peony$ 3.Shell Script編程 目的:使用UNIX所提供的最常用工具來完成所需復雜任務的強大功能。 (1)最簡單的Shell 編程 $ls -R / grep myname more 每天數據的備份: $ cd /usr/yourname; ls * cpio -o > /dev/rmt/0h 書寫程序的目的是一次編程,多次使用(執行)! $ cat > backup.sh cd /home/hbwork ls * cpio -o > /dev/rmt/0h ^D 執行: $ sh backup.sh 或: $ chmod +x backup.sh $ ./backup.sh 技巧:在shell script中加入必要的注釋,以便以後閱讀及維護。 (2)shell是一個(編程)語言 同傳統的編程語言一樣,shell提供了很多特性,這些特性可以使你的shell script 編程更為有用,如:數據變量、參數傳遞、判斷、流程控制、數據輸入和輸出,子 程序及以中斷處理等。 . 在shell編程中使用數據變量可以將程序變量更為通用,如在上面backup.sh中: cd $WORKDIR ls * cpio -o > /dev/rmt/0h . Shell編程中的注釋以#開頭 . 對shell變量進行數字運算,使用expr命令 expr integer operator integer 其中operator為+ - * / %, 但對*的使用要用轉義符\\,如: $expr 4 \\* 5 20 $int=`expr 5 + 7` $echo $int 12 (3)Shell編程的參數傳遞, 可通過命令行參數以及交互式輸入變量(read) restoreall.sh 對backup.sh程序的備份磁帶進行恢復 $cat > restoreall.sh cd $WORKDIR cpio -i < /dev/rmt/0h ^D restore1.sh:只能恢復一個文件 #restore1 --program to restore a single file cd $WORKDIR cpio -i $i < /dev/rmt/0h $restore1 file1 恢復多個文件restoreany : #restoreany --program to restore a single file cd $WORKDIR cpio -i $* < /dev/rmt/0h

$ restoreany file1 file2 file3 (4)條件判斷 . if-then語句,格式如下: if command_1 then command_2 command_3 fi command_4 在if-then語句中使用了命令返回碼$?,即當command_1執行成功時才執行command_2和 command_3,而command_4總是執行. 示例程序unload: 在備份成功時刪除原始文件,帶有錯誤檢查 cd $1 #備份時未考慮不成功的情況! ls -a cpio -o > /dev/rmt/0h rm -rf * 改進如下: #當使用了管道命令時,管理命令的返回代碼為最後一個命令的返回代碼 if ls -a cpio -o > /dev/rmt/0h then rm -rf * fi . if-then-else語句 if command_1 then command_2 else command_3 fi 技巧: 由於shell對命令中的多余的空格不作任何處理,一個好的程序員會用這一特 性 對自己的程序采用統一的縮進格式,以增強自己程序的可讀性. . 使用test命令進行進行條件測試 格式: test conditions test在以下四種情況下使用: a. 字符比較 b.兩個整數值的比較 c. 文件操作,如文件是否存在及文件的狀態等 d. 邏輯操作,可以進行and/or,與其他條件聯合使用 a. 測試字符數據: shell變量通常民政部下均作為字符變量 str1 = str2 二者相長,相同 str1 != str2 不同 -n string string不為空(長度不為零) -z string string為空 string string不為空 例: $ str1=abcd #在含有空格時必須用引號括起來 $ test $str1=abcd $ echo $? 0 $ str1="abcd " $ test $str1=abcd $ echo $? 1 Note: 在test處理含有空格的變量時最好用引號將變量括起來,否則會出現錯誤的 結果, 因為shell在處理命令行時將會去掉多余的空格,而用引號括起來則可以防止 shell去掉這些空格. 例: $ str1=" " $ test $str1 $ echo $? 1 $ test "$str1" $ echo $? 0 $ test -n $str1 test: argument expected $ test -n "$str1" $ echo $? 0 $ b. 整數測試: test與expr相同,可以將字符型變量轉換為整數進行操作,expr進行 整數的算術運算,而test則進行邏輯運算. 表達式 說明 --------------------------------------- int1 -eq int2 相等? int1 -ne int2 不等? int1 -gt int2 int1 > int2 ? int1 -ge int2 int1 >= int2 ? int1 -lt int2 int1 < int2 ? int1 -le int2 int1 <= int2 ? 例: $ int1=1234 $ int2=01234 $ test $int1 -eq $int2 $ echo $? 0 c. 文件測試:檢查文件狀態如存在及讀寫權限等 -r filename 用戶對文件filename有讀權限? -w filename 用戶對文件filename有寫權限? -x filename 用戶對文件filename有可執行權限? -f filename 文件filename為普通文件? -d filename 文件filename為目錄? -c filename 文件filename為字符設備文件? -b filename 文件filename為塊設備文件? -s filename 文件filename大小不為零? -t fnumb 與文件描述符fnumb(默認值為1)相關的設備是一個終端設備? d. 測試條件之否定,使用! 例: $ cat /dev/null > empty $ test -r empty $ echo $? 0 $ test -s empty 1 $ test ! -s empty $ echo $? 0 e. 測試條件之邏輯運算 -a And -o Or 例: $ test -r empty -a -s empty $ echo $? 1 f. 進行test測試的標准方法

因為test命令在 shell編程中占有很重要的地位,為了使shell能同其他編程語言 一樣 便於閱讀和組織, Bourne Shell在使用test測試時使用了另一種方法:用方括號將 整個 test測試括起來: $ int1=4 $ [ $int1 -gt 2 ] $ echo $? 0 例: 重寫unload程序,使用test測試 #!/bin/sh #unload - program to backup and remove files #syntax: unload Directory #check arguments if [ $# -ne 1 ] then echo "usage: $0 directory" exit 1 fi #check for valid directory name if [ ! -d "$1" ] then echo "$1 is not a directory" exit 2 fi cd $1 ls -a cpio -o > /dev/rmt/0h if [ $? -eq 0 ] then rm -rf * else echo "A problem has occured in creating backup" echo "The directory will not be ereased" echo "Please check the backup device" exit 3 fi # end of unload 在如上示例中出現了exit, exit有兩個作用:一是停止程序中其他命令的執行,二 是 設置程序的退出狀態 g. if嵌套及elif結構 if command then command else if command then command else if command then command fi fi fi 改進:使用elif結構 if command then command elif command then command elif command then command fi elif結構同if結構類似,但結構更清淅,其執行結果完全相同 返回頁首 chg1226 公社特別嘉賓 注冊: Mar 22, 2003 文章: 148 位置: China 發表於: 2003-08-21, 3:01pm 發表主題: -------------------------------------------------------------------------------- [ZZ]Bourne Shell及shell編程(2) 發信人: Altmayer (alt>>追求>>墮落>>極限>> ), 信區: GNULinux 標 題: Bourne Shell及shell編程(2) 發信站: 飲水思源 (2001年12月30日00:21:51 星期天), 站內信件 【 以下文字轉載自 Altmayer 的信箱 】 【 原文由 [email protected] 所發表 】 來 源: from altmayer.dhs.org ([211.80.41.106]) 日 期: Sun Dec 30 00:20:37 2001 標 題: LINUX選修課講課義:Bourne Shell及shell編程(2) 發信站: 碧海青天 (Thu Apr 22 23:33:45 1999), 轉信 版權聲明: 本文內容為大連理工大學LINUX選修課講義,歡迎大家轉載,但禁止使用本材料進行 任何商業性或贏利性活動。轉載時請保留本版權聲明。 作者:何斌武,[email protected],大連理工大學網絡中心,April 1999. URL: ftp://ftp.dlut.edu.cn/pub/PEOPLE/albin/ /********抱歉,為了格式不亂,我用代碼模式粘貼全文*********/ ------------------------------------------------------------------------------ 源碼:-------------------------------------------------------------------------------- Bourne Shell及Shell編程(2) h.交互式從鍵盤讀入數據 使用read語句,其格式如下: read var1 var2 ... varn read將不作變量替換,但會刪除多余的空格,直到遇到第一個換行符(回車), 並將輸入值依次賦值給相應的變量。

例: $ read var1 var2 var3 Hello my friends $ echo $var1 $var2 $var3 Hello my friends $ echo $var1 Hello $ read var1 var2 var3 Hello my dear friends $ echo $var3 dear friends <-輸入多余變量時,輸入值余下的內容賦給最後一個變量 $ read var1 var2 var3 Hello friends $ echo $var3 <- var3為空 $ 在shell script中可使用read語句進行交互操作: ... #echo -n message 輸出結果後不換行 echo -n "Do you want to continue: Y or N" read ANSWER if [ $ANSWER=N -o $ANSWER=n ] then exit fi i. case結構:結構較elif-then結構更清楚 比較if-then語句: if [ variable1 = value1 ] then command command elif [ variable1 = value2 ] then command command elif [ variable1 = value3 ] then command command fi 相應的case結構: case value in pattern1) command command;; pattern2) command command;; ... patternn) command; esac * case語句只執行第一個匹配模式 例:使用case語句建立一個菜單選擇shell script #Display a menu echo _ echo "1 Restore" echo "2 Backup" echo "3 Unload" echo #Read and excute the user's selection echo -n "Enter Choice:" read CHOICE case "$CHOICE" in 1) echo "Restore";; 2) echo "Backup";; 3) echo "Unload";; *) echo "Sorry $CHOICE is not a valid choice exit 1 esac 在上例中,*指默認匹配動作。此外,case模式中也可以使用邏輯操作,如下所示 : pattern1 pattern2 ) command command ;; 這樣可以將上面示例程序中允許用戶輸入數字或每一個大寫字母。 case "$CHOICE" in 1R) echo "Restore";; 2B) echo "Backup";; 3U) echo "Unload";; *) echo "Sorry $CHOICE is not a valid choice exit 1 esac (5)循環控制 <1> while循環: 格式: while command do command command command ... done 例: 計算1到5的平方 #!/bin/sh # #Filename: square.sh int=1 while [ $int -le 5 ] do sq=`expr $int \\* $int` echo $sq int=`expr $int + 1` done echo "Job completed" $ sh square.sh 1 4 9 16 25 Job completed <2> until循環結構: 格式: until command do command command .... command done 示例:使用until結構計算1-5的平方 #!/bin/sh int=1 until [ $int -gt 5 ] do sq=`expr $int \\* $int` echo $sq int=`expr $int + 1` done echo "Job completed" <3> 使用shift對不定長的參數進行處理 在以上的示例中我們總是假設命令行參數唯一或其個數固定,或者使用$*將整個命

令 行參數傳遞給shell script進行處理。對於參數個數不固定並且希望對每個命令參 數 進行單獨處理時則需要shift命令。使用shift可以將命令行位置參數依次移動位置 , 即$2->$1, $3->$2. 在移位之前的第一個位置參數$1在移位後將不在存在。 示例如下: #!/bin/sh # #Filename: shifter until [ $# -eq 0 ] do echo "Argument is $1 and `expr $# - 1` argument(s) remain" shift done $ shifter 1 2 3 4 Argument is 1 and 3 argument(s) remain Argument is 2 and 2 argument(s) remain Argument is 3 and 1 argument(s) remain Argument is 4 and 0 argument(s) remain $ 使用shift時,每進行一次移位,$#減1,使用這一特性可以用until循環對每個參 數進行處理,如下示例中是一個求整數和的shell script: #!/bin/sh # sumints - a program to sum a series of integers # if [ $# -eq 0 ] then echo "Usage: sumints integer list" exit 1 fi sum=0 until [ $# -eq 0 ] do sum=`expr $sum + $1` shift done echo $sum $ sh sumints 324 34 34 12 34 438 $ 使用shift的另一個原因是Bourne Shell的位置參數變量為$1~$9, 因此通過位置變 量 只能訪問前9個參數。但這並不等於在命令行上最多只能輸入9個參數。此時如果想 訪問 前9個參數之後的參數,就必須使用shift. 另外shift後可加整數進行一次多個移位,如: shift 3 <4>. for循環 格式: for var in arg1 arg2 ... argn do command .... command done 示例: $ for letter in a b c d e; do echo $letter;done a b c d e 對當前目錄下的所有文件操作: $ for i in * do if [ -f $i ] then echo "$i is a file" elif [ -d $i ] echo "$i is a directory" fi done 求命令行上所有整數之和: #!/bin/sh sum=0 for INT in $* do sum=`expr $sum + $INT` done echo $sum <6> 從循環中退出: break和continue命令 break 立即退出循環 continue 忽略本循環中的其他命令,繼續下一下循環 在shell編程中有時我們要用到進行無限循環的技巧,也就是說這種循環一直執行 碰 到break或continue命令。這種無限循環通常是使用true或false命令開始的。UNIX 系統中的true總是返加0值,而false則返回非零值。如下所示: #一直執行到程序執行了break或用戶強行中斷時才結束循環 while true do command .... command done 上面所示的循環也可以使用until false, 如下: until false do command .... command done 在如下shell script中同時使用了continue,break以及case語句中的正規表達式用 法: #!/bin/sh # Interactive program to restore, backup, or unload # a directory echo "Welcome to the menu driven Archive program" while true do # Display a Menu echo echo "Make a Choice from the Menu below" echo _ echo "1 Restore Archive" echo "2 Backup directory" echo "3 Unload directory"

echo "4 Quit" echo # Read the user's selection echo -n "Enter Choice: " read CHOICE case $CHOICE in [1-3] ) echo # Read and validate the name of the directory echo -n "What directory do you want? " read WORKDIR if [ ! -d "$WORKDIR" ] then echo "Sorry, $WORKDIR is not a directory" continue fi # Make the directory the current working directory cd $WORKDIR;; 4) :;; # :為空語句,不執行任何動作 *) echo "Sorry, $CHOICE is not a valid choice" continue esac case "$CHOICE" in 1) echo "Restoring..." cpio -i </dev/rmt/0h;; 2) echo "Archiving..." ls cpio -o >/dev/rmt/0h;; 3) echo "Unloading..." ls cpio -o >/dev/rmt/0h;; 4) echo "Quitting" break;; esac #Check for cpio errors if [ $? -ne 0 ] then echo "A problem has occurred during the process" if [ $CHOICE = 3 ] then echo "The directory will not be erased" fi echo "Please check the device and try again" continue else if [ $CHOICE = 3 ] then rm * fi fi done (6)結構化編程:定義函數 同其他高級語言一樣,shell也提供了函數功能。函數通常也稱之為子過程(subroutine) , 其定義格式如下: funcname() { command ... command; #分號 } 定義函數之後,可以在shell中對此函數進行調用,使用函數定義可以將一個復雜的程序 分 為多個可管理的程序段,如下所示: # start program setup () { command list ; } do_data () { command list ; } cleanup () { command list ; } errors () { command list ; } setup do_data cleanup # end program 技巧: . 在對函數命名時最好能使用有含義的名字,即函數名能夠比較准確的描述函數所 完成 的任務。 . 為了程序的維護方便,請盡可能使用注釋 使用函數的另一個好處就是可以在一個程序中的不同地方執行相同的命令序列(函數), 如下所示: iscontinue() { while true do echo -n "Continue?(Y/N)" read ANSWER case $ANSWER in [Yy]) return 0;; [Nn]) return 1;; *) echo "Answer Y or N";; esac done } 這樣可以在shell編程中調用iscontinue確定是否繼續執行: if iscontinue then continue else break fi ** shell函數與shell程序非常相似,但二者有一個非常重要的差別:shell程序是由子sh ell 執行的,而shell函數則是作為當前shell的一部分被執行的,因此在當前shell中可以 改 變函數的定義。此外在任意shell(包括交互式的shell)中均可定義函數,如: $ dir dir: not found $ dir () { ls -l ;} $ dir total 5875 -rw-r--r-- 1 hbwork 100 Nov 10 23:16 doc -rw-r--r-- 1 hbwork 2973806 Nov 10 23:47 ns40docs.zip -rw-r--r-- 1 hbwork 1715011 Nov 10 23:30 ns840usr.pdf

-rw-r--r-- 1 hbwork 1273409 Sep 23 1998 radsol21b6.tar.Z -rw-r--r-- 1 hbwork 7526 Nov 10 23:47 wget-log -rw-r--r-- 1 hbwork 1748 Nov 13 21:51 wget-log.1 $ unset dir $ dir () { > echo "Permission Link Owner Group File_SZ LastAccess FileName" > echo "-----------------------------------------------------------" > ls -l $*; > } $ dir Permission Link Owner Group File_SZ LastAccess FileName ----------------------------------------------------------- total 5875 -rw-r--r-- 1 hbwork 100 Nov 10 23:16 doc -rw-r--r-- 1 hbwork 2973806 Nov 10 23:47 ns40docs.zip -rw-r--r-- 1 hbwork 1715011 Nov 10 23:30 ns840usr.pdf -rw-r--r-- 1 hbwork 1273409 Sep 23 1998 radsol21b6.tar.Z -rw-r--r-- 1 hbwork 7526 Nov 10 23:47 wget-log -rw-r--r-- 1 hbwork 1748 Nov 13 21:51 wget-log.1 通常情況下,shell script是在子shell中執行的,困此在此子shell中對變量所作的 修改對父shell不起作用。點(.) 命令使用shell在不創建子shell而由當前shell讀取 並執行一個shell script, 可以通過這種方式來定義函數及變量。此外點(.)命令最 常用的功能就是通過讀取.profile來重新配置初始化login變量。如下所示: $ . .profile (csh相對於.命令的是source命令). (7)使用And/Or結構進行有條件的命令執行 <1> And , 僅當第一個命令成功時才有執行後一個命令,如同在邏輯與表達式中如果前面的 結果為真時才有必要繼續運算,否則結果肯定為假。 格式如下: command1 && command2 例:rm $TEMPDIR/* && echo "File sUCcessfully removed" 等價於 if rm $TEMPDIR/* then echo "File successfully removed" fi <2>Or, 與AND相反,僅當前一個命令執行出錯時才執行後一條命令 例: rm $TEMPDIR/* echo "File not removed" 等價與: if rm $TEMPDIR/* then command else echo "File not removed" fi <3> 混合命令條件執行 command1 && command2 && command3 當command1, command2成功時才執行command3 command1 && command2 comamnd3 僅當command1成功,command2失敗時才執行command3 當然可以根據自己的需要進行多種條件命令的組合,在此不多講述。 ( 使用getopts命令讀取unix格式選項 UNIX格式選項指如下格式的命令行參數: command -options parameters 使用格式: getopts option_string variable 具體使用方法請參考getopts的在線文檔(man getopts). 示例如下: #newdate if [ $# -lt 1 ] then date else while getopts mdyDHMSTjJwahr OPTION do case $OPTION in m) date '+%m ';; # Month of Year d) date '+%d ';; # Day of Month y) date '+%y ';; # Year D) date '+%D ';; # MM/DD/YY H) date '+%H ';; # Hour M) date '+%M ';; # Minute S) date '+%S ';; # Second T) date '+%T ';; # HH:MM:SS j) date '+%j ';; # day of year J) date '+%y%j ';;# 5 digit Julian date

Copyright © Linux教程網 All Rights Reserved