shell脚本----if(数字条件,字符串条件,字符串为空)

 

二元比较操作符,比较变量或者比较数字.

注意数字与字符串的区别.

1.整数比较 

 

[cpp] view plain copy
 
 print?
  1. -eq 等于,如:if [ "$a" -eq "$b" ]   
  2. -ne 不等于,如:if [ "$a" -ne "$b" ]   
  3. -gt 大于,如:if [ "$a" -gt "$b" ]   
  4. -ge 大于等于,如:if [ "$a" -ge "$b" ]   
  5. -lt 小于,如:if [ "$a" -lt "$b" ]   
  6. -le 小于等于,如:if [ "$a" -le "$b" ]   
  7. <   小于(需要双括号),如:(("$a" < "$b"))   
  8. <=  小于等于(需要双括号),如:(("$a" <= "$b"))   
  9. >   大于(需要双括号),如:(("$a" > "$b"))   
  10. >=  大于等于(需要双括号),如:(("$a" >= "$b"))   

小数据比较可使用AWK 

 

 

2.字符串比较

 
[cpp] view plain copy
 
 print?
  1. = 等于,如:if [ "$a" = "$b" ]   
  2. == 等于,如:if [ "$a" == "$b" ],与=等价   

 

注意:

 

比较两个字符串是否相等的办法是:
if [ "$test"x = "test"x ]; then
这里的关键有几点:
1 使用单个等号
2 注意到等号两边各有一个空格:这是unix shell的要求
3 注意到"$test"x最后的x,这是特意安排的,因为当$test为空的时候,上面的表达式就变成了x = testx,显然是不相等的。而如果没有这个x,表达式就会报错:[: =: unary operator expected

 


注意:==的功能在[[]]和[]中的行为是不同的,如下: 
[cpp] view plain copy
 
 print?
  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" 
注意: 
使用-n在[]结构中测试必须要用""把变量引起来.使用一个未被""的字符串来使用! -z 
或者就是未用""引用的字符串本身,放到[]结构中。虽然一般情况下可 

以工作,但这是不安全的.习惯于使用""来测试字符串是一种好习惯.

 

举例:

1.数字比较

 

[cpp] view plain copy
 
 print?
  1. #!/bin/bash  
  2.   
  3. i=6  
  4. a=10  
  5.   
  6. if [ $a -eq 10 ]  
  7. then  
  8.     echo "a = 10"  
  9. fi  
  10.   
  11. if [ $a -ne $i ]  
  12. then  
  13.     echo "a != $i"  
  14. fi  
  15.   
  16. if [ $a -gt $i ]  
  17. then   
  18.     echo "a > i"  
  19. fi  
  20.   
  21. if [ $a -lt $i ]  
  22. then  
  23.     echo "a < i"  
  24. else  
  25.     echo "a > i"  
  26. fi  
  27.   
  28. if(("$a" > "$i"))  
  29. then  
  30.     echo "(())a>i"  
  31. fi  
  32.   
  33. if(($a != $i))  
  34. then  
  35.     echo "(())a!=i"  
  36. fi  

备注:通过sh运行脚本,[ ]运算是可以的,而(())运行出错

 

chmod 777 后,直接./ 运行,都可以

 

2.字符串比较

 

[cpp] view plain copy
 
 print?
  1. #!/bin/bash  
  2.   
  3. a="123"  
  4. b="1234"  
  5. c="123"  
  6.   
  7. if [ "$a"x != "$b"x ]  
  8. then  
  9.     echo "a != b"  
  10. fi  
  11.   
  12. if [ "$a"x = "$c"x ]  
  13. then  
  14.     echo "a == c"  
  15. fi  

 

判断字符串为空

 

[cpp] view plain copy
 
 print?
  1. if [ -z "$d" ]  
  2. then  
  3.     echo "d is empty"  
  4. fi  


备注:

 

-e                          文件存在
-a                          文件存在(已被弃用)
-f                          被测文件是一个regular文件(正常文件,非目录或设备)
-s                          文件长度不为0
-d                          被测对象是目录
-b                          被测对象是块设备
-c                          被测对象是字符设备
-p                          被测对象是管道
-h                          被测文件是符号连接
-L                          被测文件是符号连接
-S(大写)                    被测文件是一个socket
-t                          关联到一个终端设备的文件描述符。用来检测脚本的stdin[-t0]或[-t1]是一个终端
-r                          文件具有读权限,针对运行脚本的用户
-w                          文件具有写权限,针对运行脚本的用户
-x                          文件具有执行权限,针对运行脚本的用户
-u                          set-user-id(suid)标志到文件,即普通用户可以使用的root权限文件,通过chmod +s file实现
-k                          设置粘贴位
-O                          运行脚本的用户是文件的所有者
-G                          文件的group-id和运行脚本的用户相同
-N                          从文件最后被阅读到现在,是否被修改

f1 -nt f2                   文件f1是否比f2新
f1 -ot f2                   文件f1是否比f2旧
f1 -ef f2                   文件f1和f2是否硬连接到同一个文件

posted @ 2017-07-01 13:51  fire909090  阅读(12111)  评论(0编辑  收藏  举报