shell 中if的使用

2021-07-01 21:57:20 字數 1789 閱讀 6152

shell中if做比較

shell判斷陣列中是否包含某個元素:

ary=(1 2 3)

a=2if [[ "$" =~ "$a" ]] ; then

echo "a in ary"

else

echo "a not in ary"

fi比較兩個字串是否相等的辦法是:

if [ "$test"x = "test"x ]; then

這裡的關鍵有幾點:

1 使用單個等號

2 注意到等號兩邊各有乙個空格:這是unix shell的要求

3 注意到"$test"x最後的x,這是特意安排的,因為當$test為空的時候,上面的表示式就變成了x = testx,顯然是不相等的。而如果沒有這個x,表示式就會報錯:[: =: unary operator expected

二元比較操作符,比較變數或者比較數字.注意數字與字串的區別.

整數比較

-eq 等於,如:if [ "$a" -eq "$b" ]

-ne 不等於,如:if [ "$a" -ne "$b" ]

-gt 大於,如:if [ "$a" -gt "$b" ]

-ge 大於等於,如:if [ "$a" -ge "$b" ]

-lt 小於,如:if [ "$a" -lt "$b" ]

-le 小於等於,如:if [ "$a" -le "$b" ]

大於(需要雙括號),如:(("$a" > "$b"))

>= 大於等於(需要雙括號),如:(("$a" >= "$b"))

小資料比較可使用awk

字串比較

= 等於,如:if [ "$a" = "$b" ]

== 等於,如:if [ "$a" == "$b" ],與=等價

注意:==的功能在和中的行為是不同的,如下:

1 [[ $a == z* ]] # 如果$a以"z"開頭(模式匹配)那麼將為true

2 [[ $a == "z*" ]] # 如果$a等於z*(字元匹配),那麼結果為true

34 [ $a == z* ] # file globbing 和word splitting將會發生

5 [ "$a" == "z*" ] # 如果$a等於z*(字元匹配),那麼結果為true

一點解釋,關於file globbing是一種關於檔案的速記法,比如"*.c"就是,再如~也是.

但是file globbing並不是嚴格的正規表示式,雖然絕大多數情況下結構比較像.

!= 不等於,如:if [ "$a" != "$b" ]

這個操作符將在結構中使用模式匹配.

大於,在ascii字母順序下.如:

if [[ "$a" > "$b" ]]

if [ "$a" \> "$b" ]

注意:在結構中">"需要被轉義.

具體參考example 26-11來檢視這個操作符應用的例子.

-z 字串為"null".就是長度為0.

-n 字串不為"null"

注意:使用-n在結構中測試必須要用""把變數引起來.使用乙個未被""的字串來使用! -z 或者就是未用""引用的字串本身,放到結構中。雖然一般情況下可

以工作,但這是不安全的.習慣於使用""來測試字串是一種好習慣.

if判斷式

if [ 條件判斷一 ] && (||) [ 條件判斷二 ]; then

elif [ 條件判斷三 ] && (||) [ 條件判斷四 ]; then

else

執行第三段內容程式

fi

shell中 的使用

建立 file dir1 dir2 dir3 my.file.txt 可以用 分別替換得到不同的值 刪掉第乙個 及其左邊的字串 dir1 dir2 dir3 my.file.txt 刪掉最後乙個 及其左邊的字串 my.file.txt 刪掉第乙個 及其左邊的字串 file.txt 刪掉最後乙個 及其...

shell中 的使用

1.截斷功能 拿掉第一條 及其左邊的字串 dir1 dir2 dir3 my.file.txt 拿掉最後一條 及其左邊的字串 my.file.txt 拿掉第乙個.及其左邊的字串 file.txt 拿掉最後乙個.及其左邊的字串 txt 拿掉最後條 及其右邊的字串 dir1 dir2 dir3 拿掉第一...

shell中變數的使用

有關環境變數,詳見linux環境變數詳解 test 123 區域性環境變數一般用小寫 export test 123 全域性環境變數一般用大寫 export myname xiao ba wu 變數值有空格,要用單引號圍起來 export test 也可以這樣把前面的區域性變數匯出到全域性 loca...