Bash脚本中的操作符

一、文件測试操作符
假设以下的条件成立将会返回真.
-e
文件存在
-a
文件存在
这个选项的效果与-e同样. 可是它已经被"弃用"了, 而且不鼓舞使用.
-f
表示这个文件是一个 一般 文件(并非文件夹或者设备文件)
-s
文件大小不为零
-d
表示这是一个文件夹
-b
表示这是一个块设备(软盘, 光驱, 等等.)
-c
表示这是一个字符设备(键盘, modem, 声卡, 等等.)
-p
这个文件是一个管道
-h
这是一个符号链接
-L
这是一个符号链接
-S
表示这是一个socket
-t
文件(描写叙述符)被关联到一个终端设备上
这个測试选项一般被用来检測脚本中的 stdin ( [
终端.
-t 0 ] )
或者 stdout ( [
-t 1 ] )是否来自于一个
-r
文件是否具有可读权限( 指的是正在执行这个測试命令的用户是否具有读权限)-w
文件是否具有可写权限(指的是正在执行这个測试命令的用户是否具有写权限)
-x
文件是否具有可运行权限(指的是正在运行这个測试命令的用户是否具有可运行权限)
-g
set-group-id(sgid)标记被设置到文件或文件夹上
假设文件夹具有 sgid 标记的话, 那么在这个文件夹下所创建的文件将属于拥有这个文件夹的用户组, 而
不必是创建这个文件的用户组. 这个特性对于在一个工作组中共享文件夹很实用.
-u
set-user-id (suid)标记被设置到文件上
假设一个root用户所拥有的二进制可运行文件设置了 set-user-id 标记位的话, 那么普通用户也会
以root权限来执行这个文件. [1] 这对于须要訪问系统硬件的执行程序(比方pppd和cdrecord)非
常实用. 假设没有suid标志的话, 这些二进制运行程序是不可以被非root用户调用的.
-rwsr-xr-t
1 root
178236 Oct
2
2000
/usr/sbin/pppd
对于设置了 suid 标志的文件, 在它的权限列中将会以s 表示.
-k
设置 粘贴位
对于"粘贴位"的一般了解, save-text-mode标志是一个文件权限的特殊类型. 假设文件设置了这
个标志, 那么这个文件将会被保存到缓存中, 这样能够提高訪问速度. [2] 粘贴位假设设置在目
录中, 那么它将限制写权限. 对于设置了粘贴位的文件或文件夹, 在它们的权限标记列中将会显
示t .
drwxrwxrwt
7 root
1024 May 19 21:26 tmp/
假设用户并不拥有这个设置了粘贴位的文件夹, 可是他在这个文件夹下具有写权限, 那么这个用户仅仅
能在这个文件夹下删除自己所拥有的文件. 这将有效的防止用户在一个公共文件夹中不慎覆盖或者删
除别人的文件. 比方说 /tmp 文件夹. (当然, 文件夹的全部者或者 root用户能够任意删除或重命名当中
的文件.)
-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" ]
与=等价.
==比較操作符在双中括号对和单中括号对中的行为是不同的.


 [[ $a == z* ]]
# 假设$a以"z"开头(模式匹配)那么结果将为真
 [[ $a == "z*" ]] # 假设$a与z*相等(就是字面意思全然一样), 那
么结果为真.
 
 [ $a == z* ]
# 文件扩展匹配(file globbing)和单词切割有
效.
 [ "$a" == "z*" ] # 假设$a与z*相等(就是字面意思全然一样), 那
#么结果为真.


 
!=
不等号
if [ "$a" != "$b" ]
这个操作符将在[[ ... ]]结构中使用模式匹配.
<
小于, 依照ASCII字符进行排序
if [[ "$a" < "$b" ]]
if [ "$a" \< "$b" ]
注意"<"使用在 [
] 结构中的时候须要被转义.
>
大于, 依照ASCII字符进行排序
if [[ "$a" > "$b" ]]
if [ "$a" \> "$b" ]
注意">"使用在 [
] 结构中的时候须要被转义.
參考样例 26-11, 这个样例展示了怎样使用这个比較操作符.
-z
字符串为"null", 意思就是字符串长度为零
-n
字符串不为"null".
当 -n 使用在中括号里进行条件測试的时候, 必需要把字符串用双引號引用起来. 假设採用了未引用的字符串来使用 ! -z , 甚至是在条件測试中括号(參
见样例 7-6)中仅仅使用未引用的字符串的话, 一般也是能够工作的, 然而,
这是一种不安全的习惯. 习惯于使用引用的測试字符串才是正路.


compound comparison
-a
逻辑与
exp1 -a exp2
假设表达式exp1和exp2都为真的话, 那么结果为真.
-o
逻辑或
exp1 -o exp2
假设表达式exp1和exp2中至少有一个为真的话, 那么结果为真.
这与Bash中的比較操作符&&和||很相像, 可是这个两个操作符是用在双中括号结构中的.
 [[ condition1 && condition2 ]]
-o和-a操作符一般都是和test命令或者是单中括号结构一起使用的.
 if [ "$exp1" -a "$exp2" ]


注意事项
 在一个混合測试中, 即使使用引用的字符串变量也可能还不够.
假设 $string 为空的话, [ -n "$string" -o "$a" = "$b" ] 可能会在某些版本号的Bash中产生
错误. 安全的做法是附加一个额外的字符给可能的空变量, [ "x$string" != x -o "x$a" =
"x$b" ] ("x"字符是能够相互抵消的).

posted @ 2017-06-05 19:40  wzjhoutai  阅读(208)  评论(0编辑  收藏  举报