shell if 比较
前端之家收集整理的这篇文章主要介绍了
shell if 比较,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
二元比较操作符,比较变量或者比较数字.
注意数字与字符串的区别.
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"))
小数据比较可使用AWK
2.字符串比较
- =等于,如:if["$a"="$b"]
- ==等于,如:if["$a"=="$b"],与=等价
注意:
比较两个字符串是否相等的办法是:
@H_
403_260@
if [ "$test"x = "test"x ]; then
@H_
403_260@
这里的关键有几点:
@H_
403_260@
1 使用单个等号
@H_
403_260@
2 注意到等号两边各有一个空格:这是unix shell的要求
@H_
403_260@
3 注意到"$test"x最后的x,这是特意安排的,因为当$test为空的时候,上面的表达式就变成了x = testx,显然是不相等的。而如果没有这个x,表达式就会报错:[: =: unary operator expected
注意:==的功能在[[]]和[]中的行为是不同的,如下:
- [[$a==z*]]#如果$a以"z"开头(模式匹配)那么将为true
- [[$a=="z*"]]#如果$a等于z*(字符匹配),那么结果为true
- [$a==z*]#Fileglobbing和wordsplitting将会发生
- ["$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.数字比较
- #!/bin/bash
- i=6
- a=10
- if[$a-eq10]
- 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"disempty"
- 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