linux的判断命令test小解

判断命令test可以简写为中括号[ ]。一般可以分为数值判断、字符串判断和文件判断。
注意中括号[ ]和其中的判断条件之间必须存在空格,以及判断条件的判断符号和比较值之间也需要存在空格。

如果是test单独使用,如果判断条件为真,则输入echo $?会返回0,判断条件为假则返回1-255之间任意数。

(1)数值判断

判断符号说明范例
-eq相等则为真[ $a -eq $b ]
-ne不等则为真[ $a -ne $b ]
-gt大于则为真[ $a -gt $b ]
-ge大于等于则为真[ $a -ge $b ]
-lt小于则为真[ $a -lt $b ]
-le小于等于则为真[ $a -le $b ]

操作实例:

[root@youxi1 ~]# vim a.sh
#!/bin/bash
read -p "请输入第一个数字:" num1
read -p "请输入第二个数字:" num2
if [ $num1 -eq $num2 ] ; then
    echo "第一个数字等于第二个数字"
elif [ $num1 -gt $num2 ] ; then
    echo "第一个数字大于第二个数字"
elif [ $num1 -lt $num2 ] ; then
    echo "第一个数字小于第二个数字"
else
    echo "判断失败"
fi
[root@youxi1 ~]# sh a.sh
请输入第一个数字:1
请输入第二个数字:2
第一个数字小于第二个数字
[root@youxi1 ~]# sh a.sh
请输入第一个数字:2
请输入第二个数字:1
第一个数字大于第二个数字
[root@youxi1 ~]# sh a.sh
请输入第一个数字:1
请输入第二个数字:1
第一个数字等于第二个数字
[root@youxi1 ~]# sh a.sh
请输入第一个数字:aa
请输入第二个数字:bb
a.sh: 第 4 行:[: aa: 期待整数表达式
a.sh: 第 6 行:[: aa: 期待整数表达式
a.sh: 第 8 行:[: aa: 期待整数表达式
判断失败

(2)字符串判断

判断符号说明范例
=相等则为真[ $a = $b ]
!=不等则为真[ $a != $b ]
-z字符串长度为0则为真[ -z $a ]
-n字符串长度不为0则为真[ -n $a ]
>大于则为真[ str1 > str2 ]
<小于则为真[ str1 < str2 ]

操作范例:

[root@youxi1 ~]# vim a.sh
#!/bin/bash
read -p "请输入第一个字符串:" str1
read -p "请输入第二个字符串:" str2
if [ $str1 = $str2 ] ; then
    echo "两个字符串相同"
elif [ -n $str1 ] && [ -n $str2 ] ; then
    echo "两个字符串非空"
fi
[root@youxi1 ~]# sh a.sh
请输入第一个字符串:aaa
请输入第二个字符串:bbb
两个字符串非空

操作实例2:注意,在使用字符串大小比较时候:1.字符串的顺序,大于或者小于跟sort排序不一样;2.大于和小于必须要转义;3.在test比较测试中,使用的是ASCII表,大写字母是小于小写字母的。

[root@youxi1 ~]# vim a.sh
#!/bin/bash
read -p "请输入第一个字符串:" str1
read -p "请输入第二个字符串:" str2
if [ $str1 \> $str2 ] ; then
    echo "第一个字符串大于第二个字符串"
else
    echo "第一个字符串小于第二个字符串"
fi
[root@youxi1 ~]# sh a.sh  //证明比较的不是总和
请输入第一个字符串:ab
请输入第二个字符串:ba
第一个字符串小于第二个字符串
[root@youxi1 ~]# sh a.sh  //以下两个比较证明,是逐字比较
请输入第一个字符串:aa
请输入第二个字符串:ab
第一个字符串小于第二个字符串
[root@youxi1 ~]# sh a.sh
请输入第一个字符串:aa
请输入第二个字符串:ba
第一个字符串小于第二个字符串

(3)文件判断

判断符号说明范例
-e文件或目录存在则为真[ -e file ]
-r文件存在且可读则为真[ -r file ]
-w文件存在且可写则为真[ -w file ]
-x文件存在且可执行则为真[ -x file ]
-s文件存在且至少存在一个字符则为真[ -s file]
-d文件存在且为目录则为真[ -d file ]
-f文件存在且为普通文件则为真[ -f file ]
-c文件存在且为字符型文件则为真[ -c file ]
-b文件存在且为块特殊文件则为真[ -b file ]
-ntfile1比file2新则为真[ file1 -nt file2 ]
-otfile1比file2旧则为真[ file1 -ot file2 ]
-effile1和file2为同一文件则为真[ file1 -ef file2 ]

操作范例:

[root@youxi1 ~]# vim a.sh
#!/bin/bash
read -p "请输入第一个地址:" -r addr1
read -p "请输入第二个地址:" -r addr2
if [ $addr1 -nt $addr2 ] ; then
    echo "文件1比文件2新"
elif [ $addr1 -ot $addr2 ] ; then
    echo "文件1比文件2老"
fi
[root@youxi1 ~]# touch file1 file2
[root@youxi1 ~]# stat file1
  文件:"file1"
  大小:0               块:0          IO 块:4096   普通空文件
设备:fd00h/64768d      Inode:33574997    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2019-10-12 15:17:18.341481971 +0800
最近更改:2019-10-12 15:17:18.341481971 +0800
最近改动:2019-10-12 15:17:18.341481971 +0800
创建时间:-
[root@youxi1 ~]# stat file2
  文件:"file2"
  大小:0               块:0          IO 块:4096   普通空文件
设备:fd00h/64768d      Inode:33574998    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2019-10-12 15:17:18.341481971 +0800
最近更改:2019-10-12 15:17:18.341481971 +0800
最近改动:2019-10-12 15:17:18.341481971 +0800
创建时间:-
[root@youxi1 ~]# cat file2
[root@youxi1 ~]# stat file2
  文件:"file2"
  大小:0               块:0          IO 块:4096   普通空文件
设备:fd00h/64768d      Inode:33574998    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2019-10-12 15:32:06.337458140 +0800
最近更改:2019-10-12 15:17:18.341481971 +0800
最近改动:2019-10-12 15:17:18.341481971 +0800
创建时间:-
[root@youxi1 ~]# sh a.sh  //证明和访问时间atime无关
请输入第一个地址:/root/file1
请输入第二个地址:/root/file2
[root@youxi1 ~]# echo bbb >> file2
[root@youxi1 ~]# stat file2      
  文件:"file2"
  大小:4               块:8          IO 块:4096   普通文件
设备:fd00h/64768d      Inode:33574998    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
最近访问:2019-10-12 15:32:06.337458140 +0800
最近更改:2019-10-12 15:32:59.498600870 +0800
最近改动:2019-10-12 15:32:59.498600870 +0800
创建时间:-
[root@youxi1 ~]# sh a.sh  //应该是和更改时间mtime或改动时间ctime中的一个有关
请输入第一个地址:/root/file1
请输入第二个地址:/root/file2
文件1比文件2老
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值