shell 函數與內置變量


1,特殊shell變量

$# 傳遞到腳本的參數個數
$* 以一個單字符串顯示所有向腳本傳遞的參數
$$ 腳本運行的當前進程ID號
$! 后台運行的最后一個進程的ID號
$@ 與$*相同,但是使用時加引號,並在引號中返回每個參數。
$- 顯示Shell使用的當前選項,與set命令功能相同。
$? 顯示最后命令的退出狀態。0表示沒有錯誤,其他任何值表明有錯誤。
$_ 顯示傳參的最后一個參數


command > file 將輸出重定向到 file。
command < file 將輸入重定向到 file。
command >> file 將輸出以追加的方式重定向到 file。
n > file 將文件描述符為 n 的文件重定向到 file。
n >> file 將文件描述符為 n 的文件以追加的方式重定向到 file。
n >& m 將輸出文件 m 和 n 合並。
n <& m 將輸入文件 m 和 n 合並。
<< tag 將開始標記 tag 和結束標記 tag 之間的內容作為輸入。

$ command > /dev/null
/dev/null 是一個特殊的文件,寫入到它的內容都會被丟棄;如果嘗試從該文件讀取內容,那么什么也讀不到。但是 /dev/null 文件非常有用,將命令的輸出重定向到它,會起到"禁止輸出"的效果。
如果希望屏蔽 stdout 和 $ command > /dev/null 2>&1

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

 

2,二元比較

-eq    等於
=       等於
==     等於
-ne   不等於
!=     不等於
-lt     小於
\<     小於 (ASCII) *
-le    小於等於
-gt    大於
\>    大於 (ASCII) *
-ge     大於等於
-z    字符串為空
-n    字符串不為空
>     大於
>=   大於等於
<   小於
<=   小於等於

 

 

 3,文件測試類型

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

! "非" (反轉上邊的測試結果)

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開頭進行聲明的變量



${#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*

 

 

 

 

 

 

 

 

5,中 括號

if [ CONDITION ] 測 試結構


if [[ CONDITION ]] 擴 展的測試結構


Array[1]=element1 數 組初始化


[a-z] 正 則表達式的字符范圍

 

6,大括號


${variable} 參數替換


${!variable} 間 接變量引用


{ command1; command2; . . . commandN; } 代碼塊


{string1,string2,string3,...} 大 括號擴展

 

 

7, 圓括號


( command1; command2 ) 子shell中 執行的命令組


Array=(element1 element2 element3) 數組初始化


result=$(COMMAND) 在 子shell中執行命令, 並將結果賦值給變量


>(COMMAND) 進 程替換


<(COMMAND) 進 程替換


8,雙圓括號


(( var = 78 )) 整型運算


var=$(( 20 + 5 )) 整型運算, 並將結果賦值給變量

9,引 號


"$variable" " 弱"引用 'string' "強"引用

 

 

10,后 置引用

 

result=`COMMAND` 在 子shell中運行命令, 並將結果賦值給變量



免責聲明!

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



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