二元比较 *** 作符,比较变量或者比较数字。注意数字与字符串的区别。
整数比较
-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" ],与=等价
注意:==的功能在[[]]和[]中的行为是不同的,如下:
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"
链接:https://www.jianshu.com/p/6322715ad196
摘自《实用Linux Shell编程》,比较新上市的书,4.15节使用expr进行计算的时候,变量必须是整数,不能是字符串,也不能含小数,否则会出错(命令的退出状态为非0):
$ i=hello
$ expr $i + 58
expr: non-integer argument
$ echo $?
2
利用命令expr的这一特点,可以判断某个变量是不是整数。让其参与整数运算,比如,与1相加,如果expr命令的退出状态是0(成功),表明该变量是整数,否则不是整数。见下列:
$ k=5
$ expr 1 + $k >/dev/null 2>&1# 这里只关心命令的退出状态,不关心值是多少,
# 所以将标准输出与标准错误都重定向到"黑洞"
$ echo $?
0 # 退出状态为0,说明k是整数
$ m=5.8
$ expr 1 + $m >/dev/null 2>&1
$ echo $?
2 # 退出状态非0,说明m不是整数
1、在shell编程中,输入一个数可以通过read命令来完成。
2、大于0输出该数,小于或等于0,输出0值,可以借助于if结构来判断。
3、示例如下
//read从键盘读取一个数保存到变量i中//并同时输出:“输入一个数”的字符提示
read -p "输入一个数:" i
//如果用户输入的数i大于0就输出i的值
if ((i > 0))then
echo $i
//否则就直接用echo命令输出0
else
echo 0
fi //这里if语句结束
4、执行效果如下:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)