如何在Linux中使用變量
變量通??雌饋硐?$var 這樣,但它們也有 $1、$*、$? 和 $$ 這種形式。讓我們來看看所有這些 $ 值可以告訴你什么。
有許多重要的值都存儲在 Linux 系統中,我們稱為“變量”,但實際上變量有幾種類型,并且一些有趣的命令可以幫助你使用它們。在上一篇文章中,我們研究了環境變量以及它們定義在何處。在本文中,我們來看一看在命令行和腳本中使用的變量。
用戶變量
雖然在命令行中設置變量非常容易,但是有一些有趣的技巧。要設置變量,你只需這樣做:
$ myvar=11$ myvar2="eleven"
要顯示這些值,只需這樣做:
$ echo $myvar11$ echo $myvar2eleven
你也可以使用這些變量。例如,要遞增一個數字變量,使用以下任意一個命令:
$ myvar=$((myvar+1))$ echo $myvar12$ ((myvar=myvar+1))$ echo $myvar13$ ((myvar+=1))$ echo $myvar14$ ((myvar++))$ echo $myvar15$ let "myvar=myvar+1"$ echo $myvar16$ let "myvar+=1"$ echo $myvar17$ let "myvar++"$ echo $myvar18
使用其中的一些,你可以增加一個變量的值。例如:
$ myvar0=0$ ((myvar0++))$ echo $myvar01$ ((myvar0+=10))$ echo $myvar011
通過這些選項,你可能會發現它們是容易記憶、使用方便的。
你也可以刪除一個變量 – 這意味著沒有定義它。
$ unset myvar$ echo $myvar
另一個有趣的選項是,你可以設置一個變量并將其設為只讀。換句話說,變量一旦設置為只讀,它的值就不能改變(除非一些非常復雜的命令行魔法才可以)。這意味著你也不能刪除它。
$ readonly myvar3=1$ echo $myvar31$ ((myvar3++))-bash: myvar3: readonly variable$ unset myvar3-bash: unset: myvar3: cannot unset: readonly variable
你可以使用這些設置和遞增選項中來賦值和操作腳本中的變量,但也有一些非常有用的內部變量可以用于在腳本中。注意,你無法重新賦值或增加它們的值。
內部變量
在腳本中可以使用很多變量來計算參數并顯示有關腳本本身的信息。
$1、$2、$3等表示腳本的第一個、第二個、第三個等參數。$#表示參數的數量。$*表示所有參數。$0表示腳本的名稱。$?表示先前運行的命令的返回碼(0 代表成功)。$$顯示腳本的進程 ID。$PPID顯示 shell 的進程 ID(腳本的父進程)。
其中一些變量也適用于命令行,但顯示相關信息:
$0顯示你正在使用的 shell 的名稱(例如,-bash)。$$顯示 shell 的進程 ID。$PPID顯示 shell 的父進程的進程 ID(對我來說,是 sshd)。
為了查看它們的結果,如果我們將所有這些變量都放入一個腳本中,比如:
#!/bin/bashecho $0echo $1echo $2echo $#echo $*echo $?echo $$echo $PPID
當我們調用這個腳本時,我們會看到如下內容:
$ tryme one two three/home/shs/bin/tryme <== 腳本名稱one <== 第一個參數two <== 第二個參數3 <== 參數的個數one two three <== 所有的參數0 <== 上一條 echo 命令的返回碼10410 <== 腳本的進程 ID10109 <== 父進程 ID
如果我們在腳本運行完畢后檢查 shell 的進程 ID,我們可以看到它與腳本中顯示的 PPID 相匹配:
$ echo $$10109 <== shell 的進程 ID
當然,比起簡單地顯示它們的值,更有用的方式是使用它們。我們來看一看它們可能的用處。
檢查是否已提供參數:
if [ $# == 0 ]; thenecho "$0 filename"exit 1fi
檢查特定進程是否正在運行:
ps -ef | grep apache2 > /dev/nullif [ $? != 0 ]; thenecho Apache is not runningexitfi
在嘗試訪問文件之前驗證文件是否存在:
if [ $# -lt 2 ]; thenecho "Usage: $0 lines filename"exit 1fiif [ ! -f $2 ]; thenecho "Error: File $2 not found"exit 2elsehead -$1 $2fi
在下面的小腳本中,我們檢查是否提供了正確數量的參數、第一個參數是否為數字,以及第二個參數代表的文件是否存在。
#!/bin/bashif [ $# -lt 2 ]; thenecho "Usage: $0 lines filename"exit 1fiif [[ $1 != [0-9]* ]]; thenecho "Error: $1 is not numeric"exit 2fiif [ ! -f $2 ]; thenecho "Error: File $2 not found"exit 3elseecho top of filehead -$1 $2fi
重命名變量
在編寫復雜的腳本時,為腳本的參數指定名稱通常很有用,而不是繼續將它們稱為 $1、$2 等。等到第 35 行,閱讀你腳本的人可能已經忘了 $2 表示什么。如果你將一個重要參數的值賦給 $filename 或 $numlines,那么他就不容易忘記。
#!/bin/bashif [ $# -lt 2 ]; thenecho "Usage: $0 lines filename"exit 1elsenumlines=$1filename=$2fiif [[ $numlines != [0-9]* ]]; thenecho "Error: $numlines is not numeric"exit 2fiif [ ! -f $ filename]; thenecho "Error: File $filename not found"exit 3elseecho top of filehead -$numlines $filenamefi
當然,這個示例腳本只是運行 head 命令來顯示文件中的前 x 行,但它的目的是顯示如何在腳本中使用內部參數來幫助確保腳本運行良好,或在失敗時清晰地知道失敗原因。




























