表格 B-1. 特殊的shell變量
變量 | 含義 |
---|---|
$0 |
腳本名字 |
$1 |
位置參數 #1 |
$2- $9 |
位置參數 #2 - #9 |
${10} |
位置參數 #10 |
$# |
位置參數的個數 |
"$*" |
所有的位置參數(作爲單個字符串) * |
"$@" |
所有的位置參數(每個都作爲獨立的字符串) |
${#*} |
傳遞到腳本中的命令行參數的個數 |
${#@} |
傳遞到腳本中的命令行參數的個數 |
$? |
返回值,顯示最後命令的退出狀態。0表示沒有錯誤,其他任何值表明有錯誤。 |
$$ |
腳本的進程ID(PID) |
$- |
傳遞到腳本中的標誌(使用set),顯示shell使用的當前選項,與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中運行命令, 並將結果賦值給變量 |
http://blog.csdn.net/yangzhongxuan/article/details/7493108