linux中的各種括號用法

2021-09-02 10:18:35 字數 4004 閱讀 2234

①命令組。括號中的命令將會新開乙個子shell順序執行,所以括號中的變數不能夠被指令碼餘下的部分使用。括號中多個命令之間用分號隔開,最後乙個命令可以沒有分號,各命令和括號之間不必有空格。

②命令替換。等同於`cmd`,shell掃瞄一遍命令列,發現了$(cmd)結構,便將$(cmd)中的cmd執行一次,得到其標準輸出,再將此輸出放到原來命令。有些shell不支援,如tcsh。

③用於初始化陣列。如:array=(a b c d)

①整數擴充套件。這種擴充套件計算是整數型的計算,不支援浮點型。((exp))結構擴充套件並計算乙個算術表示式的值,如果表示式的結果為0,那麼返回的退出狀態碼為1,或者 是"假",而乙個非零值的表示式所返回的退出狀態碼將為0,或者是"true"。若是邏輯判斷,表示式exp為真則為1,假則為0。

②只要括號中的運算子、表示式符合c語言運算規則,都可用在$((exp))中,甚至是三目運算子。作不同進製(如二進位制、八進位制、十六進製制)運算時,輸出結果全都自動轉化成了十進位制。如:echo $((16#5f)) 結果為95 (16進製轉十進位制)

③單純用 (( )) 也可重定義變數值,比如 a=5; ((a++)) 可將 $a 重定義為6

④雙括號中的變數可以不使用$符號字首。括號內支援多個表示式用逗號分開。

[python]view plain

copy

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]]  

fori 

in$(seq 04

);do echo $i;done  

fori 

in`seq 04

`;do echo $i;done  

for((i=

0;i<

5;i++));do echo $i;done  

fori 

in;do echo $i;done  

①bash 的內部命令,[和test是等同的。如果我們不用絕對路徑指明,通常我們用的都是bash自帶的命令。if/test結構中的左中括號是呼叫test的命令標識,右中括號是關閉條件判斷的。這個命令把它的引數作為比較表示式或者作為檔案測試,並且根據比較的結果來返回乙個退出狀態碼。if/test結構中並不是必須右中括號,但是新版的bash中要求必須這樣。

②test和中可用的比較運算子只有==和!=,兩者都是用於字串比較的,不可用於整數比較,整數比較只能使用-eq,-gt這種形式。無論是字串比較還是整數比較都不支援大於號小於號。如果實在想用,對於字串比較可以使用轉義形式,如果比較"ab"和"bc":[ ab \< bc ],結果為真,也就是返回狀態為0。[ ]中的邏輯與和邏輯或使用-a 和-o 表示。

③字元範圍。用作正規表示式的一部分,描述乙個匹配的字元範圍。作為test用途的中括號內不能使用正則。

④在乙個array 結構的上下文中,中括號用來引用陣列中每個元素的編號。

①[[是 bash 程式語言的關鍵字。並不是乙個命令,[[ ]] 結構比[ ]結構更加通用。在[[和]]之間所有的字元都不會發生檔名擴充套件或者單詞分割,但是會發生引數擴充套件和命令替換。

②支援字串的模式匹配,使用=~操作符時甚至支援shell的正規表示式。字串比較時可以把右邊的作為乙個模式,而不僅僅是乙個字串,比如[[ hello == hell? ]],結果為真。[[ ]] 中匹配字串或萬用字元,不需要引號。

③使用[[ ... ]]條件判斷結構,而不是[ ... ],能夠防止指令碼中的許多邏輯錯誤。比如,&&、||、《和》 操作符能夠正常存在於[[ ]]條件判斷結構中,但是如果出現在[ ]結構中的話,會報錯。

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

①大括號拓展。(通配(globbing))將對大括號中的檔名做擴充套件。在大括號中,不允許有空白,除非這個空白被引用或轉義。第一種:對大括號中的以逗號分割的檔案列表進行拓展。如 touch .txt 結果為a.txt b.txt。第二種:對大括號中以點點(..)分割的順序檔案列表起拓展作用,如:touch .txt 結果為a.txt b.txt c.txt d.txt

[python]view plain

copy

bogon:/home/bash 

# ls .sh

ex1.sh  ex2.sh  

bogon:/home/bash # ls ,ex4}.sh

ex1.sh  ex2.sh  ex3.sh  ex4.sh  

bogon:/home/bash # ls .sh

ex1.sh  ex2.sh  ex3.sh  ex4.sh  

②**塊,又被稱為內部組,這個結構事實上建立了乙個匿名函式 。與小括號中的命令不同,大括號內的命令不會新開乙個子shell執行,即指令碼餘下部分仍可使用括號內變數。括號內的命令間用分號隔開,最後乙個也必須有分號。{}的第乙個命令和左括號之間必須要有乙個空格。

a,$和$:若變數var為空,則用在命令列中用string來替換$,否則變數var不為空時,則用變數var的值來替換$;對於$的替換規則和$是一樣的,所不同之處是$若var為空時,用string替換$的同時,把string賦給變數var: $很常用的一種用法是,判斷某個變數是否賦值,沒有的話則給它賦上乙個預設值。

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

c,$替換規則為:若變數var不為空,則用變數var的值來替換$;若變數var為空,則把string輸出到標準錯誤中,並從指令碼中退出。我們可利用此特性來檢查是否設定了變數的值。

補充擴充套件:在上面這五種替換結構中string不一定是常值的,可用另外乙個變數的值或是一種命令的輸出。

第一種模式:$,這種模式時,shell在variable中查詢,看它是否一給的模式pattern結尾,如果是,就從命令列把variable中的內容去掉右邊最短的匹配模式

第二種模式: $,這種模式時,shell在variable中查詢,看它是否一給的模式pattern結尾,如果是,就從命令列把variable中的內容去掉右邊最長的匹配模式

第三種模式:$ 這種模式時,shell在variable中查詢,看它是否一給的模式pattern開始,如果是,就從命令列把variable中的內容去掉左邊最短的匹配模式

第四種模式: $ 這種模式時,shell在variable中查詢,看它是否一給的模式pattern結尾,如果是,就從命令列把variable中的內容去掉右邊最長的匹配模式

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

[python]view plain

copy

bogon:/home/bash 

# var=testcase

bogon:/home/bash # echo $var

testcase  

bogon:/home/bash # echo $

testca  

bogon:/home/bash # echo $var

testcase  

bogon:/home/bash # echo $

te  

bogon:/home/bash # echo $

stcase  

bogon:/home/bash # echo $

stcase  

bogon:/home/bash # echo $

bogon:/home/bash # echo $

e  bogon:/home/bash # echo $

case  

shell中的各種括號用法

一 圓括號 1 建立程序列表 例如 pwd ls cd etc pwd cd pwd ls 最後輸出的值表示子shell的數目 ls ps echo bash subshell test.sh pid tty time cmd 11949 pts 2 00 00 00 bash 15482 pts ...

shell中的各種括號

在編寫shell scripts時,經常會用到括號,各種括號,各種用法。一 括號 圓括號 1 單小括號。命令組。括號中的命令將會新開乙個子shell順序執行,所以括號中的變數不能夠被指令碼餘下的部分使用。括號中多個命令之間用分號隔開,最後乙個命令可以沒有分號,各命令和括號之間不必有空格。命令替換。等...

shell中的各種括號

1.中括號 bash 的內部命令,和test是等同,作為條件判斷結構 if then cmd fi 引用陣列中每個元素的編號 2.雙中括號 雙中括號大多數情況與單中括號相同,但是 支援字串的模式匹配,如 hello hell?且能避免許多bug if i lt5 if a ne1 a a 2 if ...