基本要素:正則表達式
Ø [ ] 兩個符號左右都要有空格分隔shell
Ø 內部操做符與操做變量之間要有空格:如 [ 「a」 = 「b」 ]bash
Ø 字符串比較中,> < 須要寫成\> \< 進行轉義post
Ø [ ] 中字符串或者${}變量儘可能使用"" 雙引號擴住,避免值未定義引用而出錯的好辦法測試
Ø [ ] 中可使用 –a –o 進行邏輯運算ui
Ø [ ] 是bash 內置命令:[ is a shell builtinurl
1.測試時邏輯操做符.net
邏輯與,操做符兩邊均爲真,結果爲真,不然爲假。 |
|
-o |
邏輯或,操做符兩邊一邊爲真,結果爲真,不然爲假。 |
! |
邏輯否,條件爲假,結果爲真。 |
舉例: [ -w result.txt-a -w score.txt ] ;echo $? // 測試兩個文件是否都可寫
二. bash [[ ]] 雙方括號
基本要素:
Ø [[ ]] 兩個符號左右都要有空格分隔
Ø 內部操做符與操做變量之間要有空格:如 [[ 「a」 = 「b」 ]]
Ø 字符串比較中,能夠直接使用 > < 無需轉義
Ø [[ ]] 中字符串或者${}變量儘可能如未使用"" 雙引號擴住的話,會進行模式和元字符匹配
[root@localhostkuohao]# [[ "ab"=a* ]] && echo "ok"
ok
Ø [[] ] 內部可使用 && || 進行邏輯運算
Ø [[ ]] 是bash keyword:[[ is a shell keyword
[[ ]] 其餘用法都和[ ] 同樣
兩者共同特性:
Ø && ||-a –o 處理
[ exp1 -a exp2 ] = [[ exp1 && exp2 ]] = [ exp1 ]&& [ exp2 ] = [[ exp1 ]] && [[ exp2 ]]
[ exp1 -o exp2 ] = [[ exp1 || exp2 ]] = [ exp1 ]|| [ exp2 ] = [[ exp1 ]] || [[ exp2 ]]
[root@localhost ~]# if [[ "a" == "a" && 2 -gt1 ]] ;then echo "ok" ;fi
ok
[root@localhost ~]# if [[ "a" == "a" ]] && [[2 -gt 1 ]] ;then echo "ok" ;fi
ok
[root@localhost ~]# if [[ "a" == "a" ]] || [[ 2 -gt 1]] ;then echo "ok" ;fi
ok
[root@localhost ~]# if [[ "a" == "a" ]] || [[ 2 -gt10 ]] ;then echo "ok" ;fi
ok
[root@localhost ~]# if [[ "a" == "a" || 2 -gt 10 ]] ;then echo "ok" ;fi
ok
Ø [[ ]] 和 [ ] 均可以和 ! 配合使用
優先級 ! > && > ||
邏輯運算符 < 關係運算符
邏輯運算符 : ! && || -a -o
關係運算符 : < > \> \< == = != – eq –ne -gt -ge –lt -le
-----------------------------------------------------------------------------
n [[ ]] 比[ ] 具有的優點
-----------------------------------------------------------------------------
①[[是 bash 程序語言的關鍵字。並非一個命令,[[ ]] 結構比[ ]結構更加通用。在[[和]]之間全部的字符都不會發生文件名擴展或者單詞分割,可是會發生參數擴展和命令替換。
②支持字符串的模式匹配,使用=~操做符時甚至支持shell的正則表達式。字符串比較時能夠把右邊的做爲一個模式,而不單單是一個字符串,好比[[ hello == hell? ]],結果爲真。[[ ]] 中匹配字符串或通配符,不須要引號。
③使用[[ ... ]]條件判斷結構,而不是[... ],可以防止腳本中的許多邏輯錯誤。好比,&&、||、<和> 操做符可以正常存在於[[ ]]條件判斷結構中,可是若是出如今[ ]結構中的話,會報錯。
④bash把雙中括號中的表達式看做一個單獨的元素,並返回一個退出狀態碼。
使用[[ ... ]]條件判斷結構, 而不是[ ... ], 可以防止腳本中的許多邏輯錯誤. 好比,&&, ||, <, 和> 操做符可以正常存在於[[]]條件判斷結構中, 可是若是出如今[ ]結構中的話, 會報錯。
#!/bin/bash
count="$1"
if [ $count -gt 15 -o $count -lt 5 ];then
echo right
fi#!/bin/bash
count="$1"
if [ $count -gt 5 -a $count -lt 15 ];then
echo right
score=$1
if [[ $score -gt 15 || $score -lt 8 && $score -ne 5 ]];then
echo right
else
echo wrong
fi
記住必須加兩個中括號
Shell中的括號有其特殊的用法, 現總結以下:
1. 符號$後的括號
${a} 變量a的值, 在不引發歧義的狀況下能夠省略大括號.
$(cmd) 命令替換, 結果爲shell命令cmd的輸出, 和`cmd`效果相同, 不過某些Shell版本不支持$()形式的命令替換, 如tcsh.
$((exp)) 和`expr exp`效果相同, 計算數學表達式exp的數值, 其中exp只要符合C語言的運算規則便可, 甚至三目運算符和邏輯表達式均可以計算.
2. 多條命令執行
(cmd1;cmd2;cmd3) 新開一個子shell順序執行命令cmd1,cmd2,cmd3, 各命令之間用分號隔開, 最後一個命令後能夠沒有分號.
{ cmd1;cmd2;cmd3;} 在當前shell順序執行命令cmd1,cmd2,cmd3, 各命令之間用分號隔開, 最後一個命令後必須有分號, 第一條命令和左括號之間必須用空格隔開.
對{}和()而言, 括號中的重定向符隻影響該條命令, 而括號外的重定向符影響到括號中的全部命令.
3. 雙括號的特殊用法
(()) 加強括號的用法, 經常使用於算術運算比較. 雙括號中的變量能夠不使用$符號前綴, 只要括號中的表達式符合C語言運算規則, 支持多個表達式用逗號分開.
好比能夠直接使用for((i=0;i<5;i++)), 若是不使用雙括號, 則爲for i in `seq 0 4`或者for i in {0..4}.
再如能夠直接使用if (($i<5)), 若是不使用雙括號, 則爲if [ $i -lt 5 ].
[[]] 加強方括號用法, 經常使用於字符串的比較. 主要用於條件測試, 雙括號中的表達式可使用&&, ||, <, >等C語言語法.
好比能夠直接使用if [[ $a != 1 && $a != 2 ]], 若是不適用雙括號, 則爲if [ $a -ne 1] && [ $a != 2 ]或者if [ $a -ne 1 -a $a != 2 ].
轉載自 https://www.cnblogs.com/jjzd/p/6397495.html