您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關如何進行Linux shell運算符的比較,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
運算符
描述 | 示例 | |
文件比較運算符 | ||
-efilename | 如果filename存在,則為真 | [ -e /var/log/syslog ] |
-dfilename | 如果filename為目錄,則為真 | [ -d /tmp/mydir ] |
-ffilename | 如果filename為常規文件,則為真 | [ -f /usr/bin/grep ] |
-Lfilename | 如果filename為符號鏈接,則為真 | [ -L /usr/bin/grep ] |
-rfilename | 如果filename可讀,則為真 | [ -r /var/log/syslog ] |
-wfilename | 如果filename可寫,則為真 | [ -w /var/mytmp.txt ] |
-xfilename | 如果filename可執行,則為真 | [ -L /usr/bin/grep ] |
filename1-ntfilename2 | 如果filename1比filename2新,則為真 | [ /tmp/install/etc/services -nt /etc/services ] |
filename1-otfilename2 | 如果filename1比filename2舊,則為真 | [ /boot/bzImage -ot arch/i386/boot/bzImage ] |
字符串比較運算符(請注意引號的使用,這是防止空格擾亂代碼的好方法) | ||
-zstring | 如果string長度為零,則為真 | [ -z "$myvar" ] |
-nstring | 如果string長度非零,則為真 | [ -n "$myvar" ] |
string1=string2 | 如果string1與string2相同,則為真 | [ "$myvar" = "one two three" ] |
string1!=string2 | 如果string1與string2不同,則為真 | [ "$myvar" != "one two three" ] |
算術比較運算符 | ||
num1-eqnum2 | 等于 | [ 3 -eq $mynum ] |
num1-nenum2 | 不等于 | [ 3 -ne $mynum ] |
num1-ltnum2 | 小于 | [ 3 -lt $mynum ] |
num1-lenum2 | 小于或等于 | [ 3 -le $mynum ] |
num1-gtnum2 | 大于 | [ 3 -gt $mynum ] |
num1-genum2 | 大于或等于 | [ 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/bashvar1="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條件是為真的時候執行,如果使用!運算符,那么原表達式必須為falseif ! test $var1 != "1"; then echo "not 1"fi
以上三個if都為真,所以三個echo都會打印
示例:
#!/bin/shaa="August 15, 2012" bb="August 15, 20122" cc="123" dd="123"# -o if [ "$aa" = "$bb" -o "$cc" = "$dd" ]; thenecho "yes" elseecho "no" fi# -a and ! if [ "$aa" != "$bb" -a "$cc" = "$dd" ]; thenecho "yes" elseecho "no" fi
#!/bin/bashfile='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))doecho "down again..." done
其中,下面三種整數比較都成立: 1) while [ ! -f $file -o "$fileSize" -lt "$FILESIZE" ] 2) while [ ! -f $file -o "$fileSize" -lt 1000 ] 3) (("$fileSize" < 1000)) 推薦使用第一種 2 字符串比較 = 等于,如:if [ "$a" = "$b" ] == 等于,如:if [ "$a" == "$b" ],與=等價 注意:==的功能在[[]]和[]中的行為是不同的,如下: 1 [[ $a == z* ]] # 如果$a以"z"開頭(模式匹配)那么將為true 2 [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么結果為true 3 4 [ $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" ] 注意:在[]結構中"<"需要被轉義. > 大于,在ASCII字母順序下.如: if [[ "$a" > "$b" ]] if [ "$a" \> "$b" ] 注意:在[]結構中">"需要被轉義. 具體參考Example 26-11來查看這個操作符應用的例子. -z 字符串為"null".就是長度為0 -n 字符串不為"null" 判斷shell傳入的參數個數是否為空:
#!/bin/bashport=6379# 命令行沒參數,默認指定端口號為 6379 if [ $# -ge 1 ]; then # 命令行參數個數大于等于1,則使用傳入的參數portport=$1# 獲取指定端口號 fiecho "redis port: $port" redis-cli -h 172.1628.10.114 -p $port
字符串比較實例: if [ "$var1" = "$var2" ] 代碼:
#!/bin/shaa="August 15, 2012" bb="August 15, 2012"if [ "$aa" = "$bb" ]; thenecho "yes" elseecho "no" fi
判斷子字符串包含關系: =~ 代碼:
a1="ithomer" a2="ithomer.net" a3="blog.ithomer.net"if [[ "$a3" =~ "$a1" ]]; thenecho "$a1是$a3的子串!" elseecho "$a1不是$a3的子串!" fiif [[ "$a3" =~ "$a2" ]];thenecho "$a2是$a3的子串!" elseecho "$a2不是$a3的子串!" fi
注意: 使用-n在[]結構中測試必須要用""把變量引起來.使用一個未被""的字符串來使用! -z或者就是未用""引用的字符串本身,放到[]結構中。雖然一般情況下可以工作,但這是不安全的.習慣于使用""來測試字符串是一種好習慣. awk '{print $2}' class.txt | grep '^[0-9.]' > res
上述就是小編為大家分享的如何進行Linux shell運算符的比較了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。