shell中的參數擴展, 特殊變量


echo $SHLVL  該變量包含當前工作的shell level

$*  所有參數列表 受IFS控制

PS1 為提示符,可進行設置 PS1="[\u@\h \W]\$"
PS2 為換行時的那個符號如 aa '換行后默認會出現>我們可以進行修改 PS2=''換成你喜歡的
IFS 為變量的分隔符,默認是空格

 

表格 B-1. 特殊的shell變量

變量 含義
$0 shellshell腳本的名字
$1 位置參數 #1
$2 - $9 位置參數 #2 - #9
${10} 位置參數 #10
$# 位置參數的個數
"$*" 所有的位置參數(整體作為單個字符串) *
"$@" 所有的位置參數(每個都作為獨立的字符串)
${#*} 傳遞到腳本中的命令行參數的個數
${#@} 傳遞到腳本中的命令行參數的個數
$? 返回值
$$ 腳本的進程ID(PID)
$- 傳遞到腳本中的標志(使用set)
$_ 之前命令的最后一個參數
$! 運行在后台的最后一個作業的進程ID(PID)

* 必須被引用起來, 否則默認為"$@".


表格 B-2. 測試操作: 二元比較

操作 描述 ----- 操作 描述
         
算術比較     字符串比較  
-eq 等於   = 等於
      == 等於
-ne 不等於   != 不等於
-lt 小於   \< 小於 (ASCII) *
-le 小於等於      
-gt 大於   \> 大於 (ASCII) *
-ge 大於等於      
      -z 字符串為空
      -n 字符串不為空
         
算術比較 雙括號(( ... ))結構      
> 大於      
>= 大於等於      
< 小於      
<= 小於等於      

* 如果在雙中括號[[ ... ]]測試結構中使用的話, 那么就不需要使用轉義符\了.


表格 B-3. 文件類型的測試操作

操作 測試條件 ----- 操作 測試條件
-e 文件是否存在   -s 文件大小不為0
-f 是一個標准文件      
-d 是一個目錄   -r 文件具有權限
-h 文件是一個符號鏈接   -w 文件具有權限
-L 文件是一個符號鏈接   -x 文件具有執行權限
-b 文件是一個塊設備      
-c 文件是一個字符設備   -g 設置了sgid標記
-p 文件是一個管道   -u 設置了suid標記
-S 文件是一個socket   -k 設置了"粘貼位"
-t 文件與一個終端相關聯      
         
-N 從這個文件最后一次被讀取之后, 它被修改過   F1 -nt F2 文件F1比文件F2*
-O 這個文件的宿主是你   F1 -ot F2 文件F1比文件F2*
-G 文件的組id與你所屬的組相同   F1 -ef F2 文件F1和文件F2都是同一個文件的硬鏈接*
         
! "非"(反轉上邊的測試結果)      

* 二元操作符(需要兩個操作數).


表格 B-4. 參數替換和擴展

表達式 含義
${var} 變量var的值, 與$var相同
   
${var-DEFAULT} 如果var沒有被聲明, 那么就以$DEFAULT作為其值 *
${var:-DEFAULT} 如果var沒有被聲明, 或者其值為空, 那么就以$DEFAULT作為其值 *
   
${var=DEFAULT} 如果var沒有被聲明, 那么就以$DEFAULT作為其值 *
${var:=DEFAULT} 如果var沒有被聲明, 或者其值為空, 那么就以$DEFAULT作為其值 *
   
${var+OTHER} 如果var聲明了, 那么其值就是$OTHER, 否則就為null字符串
${var:+OTHER} 如果var被設置了其值不為空, 那么其值就是$OTHER, 否則就為null字符串
   
${var?ERR_MSG} 如果var沒被聲明, 那么就打印$ERR_MSG*
${var:?ERR_MSG} 如果var沒被設置其值為空, 那么就打印$ERR_MSG*
   
${!varprefix*} 匹配之前所有以varprefix開頭進行聲明的變量
${!varprefix@} 匹配之前所有以varprefix開頭進行聲明的變量

*當然, 如果變量var已經被設置的話, 那么其值就是$var.


表格 B-5. 字符串操作

表達式 含義
${#string} $string的長度
   
${string:position} $string中, 從位置$position開始提取子串
${string:position:length} $string中, 從位置$position開始提取長度為$length的子串
   
${string#substring} 從變量$string的開頭, 刪除最短匹配$substring的子串
${string##substring} 從變量$string的開頭, 刪除最長匹配$substring的子串
${string%substring} 從變量$string的結尾, 刪除最短匹配$substring的子串
${string%%substring} 從變量$string的結尾, 刪除最長匹配$substring的子串
   
${string/substring/replacement} 使用$replacement, 來代替第一個匹配的$substring
${string//substring/replacement} 使用$replacement, 代替所有匹配的$substring
${string/#substring/replacement} 如果$string前綴匹配$substring, 那么就用$replacement來代替匹配到的$substring
${string/%substring/replacement} 如果$string后綴匹配$substring, 那么就用$replacement來代替匹配到的$substring
   
   
expr match "$string" '$substring' 匹配$string開頭的$substring*的長度
expr "$string" : '$substring' 匹配$string開頭的$substring*的長度
expr index "$string" $substring $string中匹配到的$substring的第一個字符出現的位置
expr substr $string $position $length $string中從位置$position開始提取長度為$length的子串
expr match "$string" '\($substring\)' $string的開頭位置提取$substring*
expr "$string" : '\($substring\)' $string的開頭位置提取$substring*
expr match "$string" '.*\($substring\)' $string的結尾提取$substring*
expr "$string" : '.*\($substring\)' $string的結尾提取$substring*

* $substring是一個正則表達式.


表格 B-6. 一些結構的匯總

表達式 解釋
   
中括號  
if [ CONDITION ] 測試結構
if [[ CONDITION ]] 擴展的測試結構
Array[1]=element1 數組初始化
[a-z] 正則表達式的字符范圍
   
大括號  
${variable} 參數替換
${!variable} 間接變量引用
{ command1; command2; . . . commandN; } 代碼塊
{string1,string2,string3,...} 大括號擴展
   
   
圓括號  
( command1; command2 ) 子shell中執行的命令組
Array=(element1 element2 element3) 數組初始化
result=$(COMMAND) 在子shell中執行命令, 並將結果賦值給變量
>(COMMAND) 進程替換
<(COMMAND) 進程替換
   
雙圓括號  
(( var = 78 )) 整型運算
var=$(( 20 + 5 )) 整型運算, 並將結果賦值給變量
   
引號  
"$variable" "弱"引用
'string' "強"引用
   
后置引用  
result=`COMMAND` 在子shell中運行命令, 並將結果賦值給變量

可以這樣理解一下:-(減號)就是變量不存在(被減掉的意思)時, 返回缺省值

                             +(加號)就是變量存在(加號代表正, 正就是存在的意思)時, 返回缺省值

                             =(等號,賦值號)和減號(-)的效果類似, 只是影響到了舊的變量


免責聲明!

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



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