您的位置:首页 > 运维架构 > Shell

shell脚本--if判断(数字条件、字符串条件)

2016-05-11 00:56 666 查看
二元比较操作符,比较变量或者比较数字.

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

1.整数比较

[cpp]
view plaincopy

-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"))

小数据比较可使用AWK
2.字符串比较

[cpp]
view plaincopy

= 等于,如: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

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

[cpp]
view plaincopy

[[ $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

或者就是未用""引用的字符串本身,放到[]结构中。虽然一般情况下可

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

举例:

1.数字比较

[cpp]
view plaincopy

#!/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.字符串比较

[cpp]
view plaincopy

#!/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

判断字符串为空

[cpp]
view plaincopy

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: