二元比较操作符,比较变量或者比较数字.
注意数字与字符串的区别.
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"))
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
以工作,但这是不安全的.习惯于使用""来字符串是一种好习惯.
举例:
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
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是否硬连接到同一个文件