1. 程式人生 > >shell中各種括號()、(())、[]、[[]]、{}的作用

shell中各種括號()、(())、[]、[[]]、{}的作用

pre 子shell 長度 home 不同 str 標準 去掉 能夠

技巧小結:

字符串比較用雙中括號[[ ]];算數比較用單中括號[ ]——左右留空格

算數運算用雙小括號(( )) ;shell命令及輸出用小括號( )——左右不留空格

快速替換用花括號{ }——左右留空格

反單引號起著命令替換的作用


單括號():

另開命令組——小括號中的內容會開啟一個子shell獨立運行;括號中以分號連接,最後一個命令不需要;各命令和括號無空格

得到命令輸出——a=$(command), 等同於a=$command,得到命令輸出傳遞給變量a

初始化數組——array=(a b c d)

雙括號(()):

省去$符號的算術運算—— for((i=0;i<5;i++)); if (($i<5)); a=5; ((a++)) 可將 $a 重定義為6;括號內支持多個表達式用逗號分開。

C語言規則運算——$((exp)),exp為符合C語言規則的運算符,表達式

跨進制運算——二進制、八進制、十六進制運算時,輸出結果全都自動轉化成了十進制。如:echo $((16#5f)) 結果為95 (16進位轉十進制)

單中括號[ ]:

字符串比較——==和!=

整數比較——不等於:-gt:大於;-lt :小於;-eq:等於;-ne

數組索引——array[0]

雙中括號[[]]:

字符串比較——可以把右邊的作為一個模式,而不僅僅是一個字符串,比如[[ hello == hell? ]],結果為真。[[ ]] 中匹配字符串或通配符,不需要引號。

邏輯運算符——防止腳本許多邏輯錯誤,比如,&&、||、<和> 操作符能夠正常存在於[[ ]]條件判斷結構中,但是如果出現在[ ]結構中的話,會報錯。比如可以直接使用if [[ $a != 1 && $a != 2 ]], 如果不適用雙括號, 則為if [ $a -ne 1] && [ $a != 2 ]或者if [ $a -ne 1 -a $a != 2 ]。

退出碼——bash把雙中括號中的表達式看作一個單獨的元素,並返回一個退出狀態碼。

if ($i<5)
if [ $i -lt 5 ]
if [ $a -ne 1 -a $a != 2 ]
if [ $a -ne 1] && [ $a != 2 ]
if [[ $a != 1 && $a != 2 ]]

for i in $(seq 0 4);do echo $i;done
for i in seq 0 4;do echo $i;done
for ((i=0;i<5;i++));do echo $i;done

for i in {0..4};do echo $i;done
大括號{}:
創建匿名函數——不會新開進程,括號內變量余下仍可使用。括號內的命令間用分號隔開,最後一個也必須有分號。{}的第一個命令和左括號之間必須要有一個空格。

特殊替換——${var:-string},${var:+string},${var:=string},${var:?string}

  ①${var:-string}和${var:=string}:若變量var為空,則用在命令行中用string來替換${var:-string},否則變量var不為空時,則用變量var的值來替換${var:-string};不同之處是${var:=string}常用於判斷var是否賦值,沒有的話則給var賦上一個默認值。

  ② ${var:+string}:替換規則和上面的相反,即只有當var不是空的時候才替換成string,若var為空時則不替換或者說是替換成變量 var的值,即空值。(因為變量var此時為空,所以這兩種說法是等價的) 

  ③${var:?string}:替換規則為:若變量var不為空,則用變量var的值來替換${var:?string};若變量var為空,則把string輸出到標準錯誤中,並從腳本中退出。我們可利用此特性來檢查是否設置了變量的值。

註意:在上面這五種替換結構中string不一定是常值的,可用另外一個變量的值或是一種命令的輸出。

模式匹配替換——${var%pattern},${var%%pattern},${var#pattern},${var##pattern}

# 是去掉左邊(在鍵盤上#在$之左邊);% 是去掉右邊(在鍵盤上%在$之右邊);#和%中的單一符號是最小匹配,兩個相同符號是最大匹配。

第一種模式:${variable%pattern}。shell在variable中查找,看它是否一給的模式pattern結尾,如果是,把variable去掉右邊最短的匹配模式

第二種模式: ${variable%%pattern},這種模式時,shell在variable中查找,看它是否一給的模式pattern結尾,如果是,把variable中去掉右邊最長的匹配模式

第三種模式:${variable#pattern} 這種模式時,shell在variable中查找,看它是否一給的模式pattern開始,如果是,把variable中去掉左邊最短的匹配模式

第四種模式: ${variable##pattern} 這種模式時,shell在variable中查找,看它是否一給的模式pattern結尾,如果是,把variable中去掉左邊最長的匹配模式

這四種模式中都不會改變variable的值,其中,只有在pattern中使用了匹配符號時,%和%%,#和##才有區別。結構中的pattern支持通配符,表示零個或多個任意字符,?表示僅與一個任意字符匹配,[...]表示匹配中括號裏面的字符,[!...]表示不匹配中括號裏面的字符。

# var=testcase
# echo $var
testcase
# echo ${var%se}
testca
# echo $var
testcase
# echo ${var%%s
e}
te
# echo ${var#?e}
stcase
# echo ${var##?e}
stcase
# echo ${var##*e} **

*# echo ${var##s}
e
# echo ${var##test} **
case
字符串提取和替換——${var:num},${var:num1:num2},${var/pattern/pattern},${var//pattern/pattern}
第一種模式:${var:num},shell在var中提取第num個字符到末尾的所有字符。若num為正數,從左邊0處開始;若num為負數,從右邊開始提取字串,但必須使用在冒號後面加空格或一個數字或整個num加上括號,如${var: -2}、${var:1-3}或${var:(-2)}。

第二種模式:${var:num1:num2},num1是位置,num2是長度。表示從$var字符串的第$num1個位置開始提取長度為$num2的子串。不能為負數。

第三種模式:${var/pattern/pattern}表示將var字符串的第一個匹配的pattern替換為另一個pattern。

第四種模式:${var//pattern/pattern}表示將var字符串中的所有能匹配的pattern替換為另一個pattern。

[root@centos ~]# var=/home/centos
[root@centos ~]# echo $var
/home/centos
[root@centos ~]# echo ${var:5}
/centos
[root@centos ~]# echo ${var: -6}
centos
[root@centos ~]# echo ${var:(-6)}
centos
[root@centos ~]# echo ${var:1:4}
home
[root@centos ~]# echo ${var/o/h}
/hhme/centos
[root@centos ~]# echo ${var//o/h}
/hhme/cenths
對{}和()而言, 括號中的重定向符只影響該條命令, 而括號外的重定向符影響到括號中的所有命令。

符號$後的括號

(1)${a} 變量a的值, 在不引起歧義的情況下可以省略大括號。

(2)$(cmd) 命令替換,和cmd效果相同,結果為shell命令cmd的輸,過某些Shell版本不支持$()形式的命令替換, 如tcsh。

(3)$((expression)) 和exprexpression效果相同, 計算數學表達式exp的數值, 其中exp只要符合C語言的運算規則即可, 甚至三目運算符和邏輯表達式都可以計算。

shell中各種括號()、(())、[]、[[]]、{}的作用