shell if条件判断语句包括数字条件与字符串条件等

发布时间:2019-08-11编辑:脚本学堂
有关shell条件判断语句的用法,包括整数比较、字符串比较,shell if语句的几个例子,供大家学习参考。

shell/ target=_blank class=infotextkey>shell脚本
二元比较操作符,比较变量或者比较数字.
注意数字与字符串的区别.

shell条件判断语句中,常用的比较参数或选项,如下:

1、整数比较
 

-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"))  
>   大于(需要双括号),如:(("$a" > "$b"))  
>=  大于等于(需要双括号),如:(("$a" >= "$b"))  

小数据比较可使用linuxjishu/13830.html target=_blank class=infotextkey>awk

2、字符串比较
 

= 等于,如:if [ "$a" = "$b" ]  
== 等于,如:if [ "$a" == "$b" ],与=等价  

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

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

[[ $a == z* ]]   # 如果$a以"z"开头(模式匹配)那么将为true  
[[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么结果为true  
 
[ $a == z* ]     # File globbing 和word splitting将会发生  
[ "$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
或者就是未用""引用的字符串本身,放到[]结构中。虽然一般情况下可
以工作,但这是不安全的.习惯于使用""来测试字符串是一种好习惯.

举例(shell if语句用法):
1.数字比较
 

#!/bin/bash 
 
i=6 
a=10 
 
if [ $a -eq 10 ] 
then 
    echo "a = 10" 
fi 
 
if [ $a -ne $i ] 
then 
    echo "a != $i" 
fi 
 
if [ $a -gt $i ] 
then  
    echo "a > i" 
fi 
 
if [ $a -lt $i ] 
then 
    echo "a < i" 
else 
    echo "a > i" 
fi 
 
if(("$a" > "$i")) 
then 
    echo "(())a>i" 
fi 
 
if(($a != $i)) 
then 
    echo "(())a!=i" 
fi 

备注:通过sh运行脚本,[ ]运算是可以的,而(())运行出错
chmod 777 后,直接./ 运行,都可以

2.字符串比较
 

#!/bin/bash 
 
a="123" 
b="1234" 
c="123" 
 
if [ "$a"x != "$b"x ] 
then 
    echo "a != b" 
fi 
 
if [ "$a"x = "$c"x ] 
then 
    echo "a == c" 
fi 

判断字符串为空
 

if [ -z "$d" ] 
then 
    echo "d is empty" 
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是否硬连接到同一个文件
 

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

整数比较:
 

-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" ))
>   大于(...)   (( "$a" > "$b" ))
>=  大于等于(...)(( "$a" >= "$b" ))

字符串比较:
 

=   等于   if [ "$a" = "$b" ]
==  与=等价
!=  不等于 if [ "$a" = "$b" ]
<   小于,在ASCII字母中的顺序:
    if [[ "$a" < "$b" ]]
    if [ "$a" < "$b" ] #需要对<进行转义
>   大于
-z  字符串为null,即长度为0
-n  字符串不为null,即长度不为0