算術運算符 + - * / % 表示加減乘除和取餘運算+= -= *= /= 同 C 語言中的含義 位操作符 > >>= 表示位左右移一位操作& &= | |= 表示按位與、位或操作~ ! 表示非操作^ ^= 表示異或操作 關係運算符 = == != 表示大於、小於、大於等於、小於等於、等於、不等於 ...
運算符 | 描述 | 示例 |
文件比較運算符 | ||
-e filename | 如果 filename 存在,則為真 | [ -e /var/log/syslog ] |
-d filename | 如果 filename 為目錄,則為真 | [ -d /tmp/mydir ] |
-f filename | 如果 filename 為常規文件,則為真 | [ -f /usr/bin/grep ] |
-L filename | 如果 filename 為符號鏈接,則為真 | [ -L /usr/bin/grep ] |
-r filename | 如果 filename 可讀,則為真 | [ -r /var/log/syslog ] |
-w filename | 如果 filename 可寫,則為真 | [ -w /var/mytmp.txt ] |
-x filename | 如果 filename 可執行,則為真 | [ -L /usr/bin/grep ] |
filename1 -nt filename2 | 如果 filename1 比 filename2 新,則為真 | [ /tmp/install/etc/services -nt /etc/services ] |
filename1 -ot filename2 | 如果 filename1 比 filename2 舊,則為真 | [ /boot/bzImage -ot arch/i386/boot/bzImage ] |
字元串比較運算符 (請註意引號的使用,這是防止空格擾亂代碼的好方法) | ||
-z string | 如果 string 長度為零,則為真 | [ -z "$myvar" ] |
-n string | 如果 string 長度非零,則為真 | [ -n "$myvar" ] |
string1 = string2 | 如果 string1 與 string2 相同,則為真 | [ "$myvar" = "one two three" ] |
string1 != string2 | 如果 string1 與 string2 不同,則為真 | [ "$myvar" != "one two three" ] |
算術比較運算符 | ||
num1 -eq num2 | 等於 | [ 3 -eq $mynum ] |
num1 -ne num2 | 不等於 | [ 3 -ne $mynum ] |
num1 -lt num2 | 小於 | [ 3 -lt $mynum ] |
num1 -le num2 | 小於或等於 | [ 3 -le $mynum ] |
num1 -gt num2 | 大於 | [ 3 -gt $mynum ] |
num1 -ge num2 | 大於或等於 | [ 3 -ge $mynum ] |
算術運算符
+ - * / % 表示加減乘除和取餘運算
+= -= *= /= 同 C 語言中的含義
位操作符
> >>= 表示位左右移一位操作
& &= | |= 表示按位與、位或操作
~ ! 表示非操作
^ ^= 表示異或操作
關係運算符
= == != 表示大於、小於、大於等於、小於等於、等於、不等於操作
&& || 邏輯與、邏輯或操作
測試命令 test命令用於檢查某個條件是否成立,它可以進行數值、字元和文件3個方面的測試,其測試符和相應的功能分別如下。 (1)數值測試: -eq 等於則為真。 -ne 不等於則為真。 -gt 大於則為真。 -ge 大於等於則為真。 -lt 小於則為真。 -le 小於等於則為真。 (2)字串測試: = 等於則為真。 != 不相等則為真。 -z字串 字串長度偽則為真。 -n字串 字串長度不偽則為真。 (3)文件測試: -e文件名 如果文件存在則為真。 -r文件名 如果文件存在且可讀則為真。 -w文件名 如果文件存在且可寫則為真。 -x文件名 如果文件存在且可執行則為真。 -s文件名 如果文件存在且至少有一個字元則為真。 -d文件名 如果文件存在且為目錄則為真。 -f文件名 如果文件存在且為普通文件則為真。 -c文件名 如果文件存在且為字元型特殊文件則為真。 -b文件名 如果文件存在且為塊特殊文件則為真 |
條件變數替換:
Bash Shell可以進行變數的條件替換,既只有某種條件發生時才進行替換,替換
條件放在{}中.
(1) ${value:-word}
當變數未定義或者值為空時,返回值為word的內容,否則返回變數的值.
(2) ${value:=word}
與前者類似,只是若變數未定義或者值為空時,在返回word的值的同時將 word賦值給value
(3) ${value:?message}
若變數已賦值的話,正常替換.否則將消息message送到標準錯誤輸出(若此替換出現在Shell程式中,那麼該程式將終止運行)
(4) ${value:+word}
若變數已賦值的話,其值才用word替換,否則不進行任何替換
(5) ${value:offset}
${value:offset:length} 從變數中提取子串,這裡offset和length可以是算術表達式.
(6) ${#value}
變數的字元個數
(7) ${value#pattern}
${value##pattern}
去掉value中與pattern相匹配的部分,條件是value的開頭與pattern相匹配
#與##的區別在於一個是最短匹配模式,一個是最長匹配模式.
(8) ${value%pattern}
${value%%pattern}
於(7)類似,只是是從value的尾部於pattern相匹配,%與%%的區別與#與##一樣
(9) ${value/pattern/string}
${value//pattern/string}
進行變數內容的替換,把與pattern匹配的部分替換為string的內容,/與//的區別與上同
註意: 上述條件變數替換中,除(2)外,其餘均不影響變數本身的值
#!/bin/bash
var1="1"
var2="2"
下麵是“與”運算符-a,另外註意,用一個test命令就可以了,還有if條件後面的分號
if test $var1 = "1"-a $var2 = "2" ; then
echo "equal"
fi
下麵是“或”運算符 -o,有一個為真就可以
if test $var1 != "1" -o $var2 != "3" ; then
echo "not equal"
fi
下麵是“非”運算符 !
if條件是為真的時候執行,如果使用!運算符,那麼原表達式必須為false
if ! test $var1 != "1"; then
echo "not 1"
fi
以上三個if都為真,所以三個echo都會列印
示例:
#!/bin/sh aa="August 15, 2012" bb="August 15, 20122" cc="123" dd="123" # -o if [ "$aa" = "$bb" -o "$cc" = "$dd" ]; then echo "yes" else echo "no" fi # -a and ! if [ "$aa" != "$bb" -a "$cc" = "$dd" ]; then echo "yes" else echo "no" fi運行結果: true
------------------------------------------------------------------------------------------------------
shell字元串比較、判斷是否為數字
二元比較操作符,比較變數或者比較數字.註意數字與字元串的區別. -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")) > 大於(需要雙括弧),如:(("$a" > "$b")) >= 大於等於(需要雙括弧),如:(("$a" >= "$b")) |
#!/bin/bash file='folder_url_top24/url_usa_top24_0' fileSize=`ls -l folder_url_top24/url_usa_top24_0 | awk -F '[" "]' '{print $5}'` FILESIZE=1000 #while [ ! -f $file -o "$fileSize" -lt "$FILESIZE" ] #while [ ! -f $file -o "$fileSize" -lt 1000 ] while (("$fileSize" < 1000)) do echo "down again..." done
二元比較操作符,比較變數或者比較數字.註意數字與字元串的區別. -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")) > 大於(需要雙括弧),如:(("$a" > "$b")) >= 大於等於(需要雙括弧),如:(("$a" >= "$b")) [css] view plain copy print?
1) while [ ! -f $file -o "$fileSize" -lt "$FILESIZE" ] 2) while [ ! -f $file -o "$fileSize" -lt 1000 ] 3) (("$fileSize" < 1000)) 推薦使用第一種 == 等於,如:if [ "$a" == "$b" ],與=等價 != 不等於,如:if [ "$a" != "$b" ] < 小於,在ASCII字母順序下.如: > 大於,在ASCII字母順序下.如: -z 字元串為"null".就是長度為0 -n 字元串不為"null"
判斷shell傳入的參數個數是否為空: |
- #!/bin/bash
- file='folder_url_top24/url_usa_top24_0'
- fileSize=`ls -l folder_url_top24/url_usa_top24_0 | awk -F '[" "]' '{print $5}'`
- FILESIZE=1000
- #while [ ! -f $file -o "$fileSize" -lt "$FILESIZE" ]
- #while [ ! -f $file -o "$fileSize" -lt 1000 ]
- while (("$fileSize" < 1000))
- do
- echo "down again..."
- done
#!/bin/bash port=6379 # 命令行沒參數,預設指定埠號為 6379 if [ $# -ge 1 ]; then # 命令行參數個數大於等於1,則使用傳入的參數port port=$1 # 獲取指定埠號 fi echo "redis port: $port" redis-cli -h 172.1628.10.114 -p $port
字元串比較實例:
if [ "$var1" = "$var2" ]
代碼:
#!/bin/sh aa="August 15, 2012" bb="August 15, 2012" if [ "$aa" = "$bb" ]; then echo "yes" else echo "no" fi
判斷子字元串包含關係: =~
代碼:
a1="ithomer" a2="ithomer.net" a3="blog.ithomer.net" if [[ "$a3" =~ "$a1" ]]; then echo "$a1是$a3的子串!" else echo "$a1不是$a3的子串!" fi if [[ "$a3" =~ "$a2" ]];then echo "$a2是$a3的子串!" else echo "$a2不是$a3的子串!" fi
註意:
使用-n在[]結構中測試必須要用""把變數引起來.使用一個未被""的字元串來使用! -z或者就是未用""引用的字元串本身,放到[]結構中。雖然一般情況下可以工作,但這是不安全的.習慣於使用""來測試字元串是一種好習慣.
awk '{print $2}' class.txt | grep '^[0-9.]' > res