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中運行命令, 並將結果賦值給變量