我的问题可以简化到使下面的脚本工作(这需要1个命令行参数):击:简单的if语句
#!/bin/bash
if ["$1" == "0"]; then
echo "good"
else
echo "bad"
fi
这应该打印好当我运行脚本0,但我无法得到它。我已经尝试过各种数字的引号组合,并且我尝试了=,==和-eq。所以... bash,它是如何工作的?
我的问题可以简化到使下面的脚本工作(这需要1个命令行参数):击:简单的if语句
#!/bin/bash
if ["$1" == "0"]; then
echo "good"
else
echo "bad"
fi
这应该打印好当我运行脚本0,但我无法得到它。我已经尝试过各种数字的引号组合,并且我尝试了=,==和-eq。所以... bash,它是如何工作的?
[
的之间的空间实际上是一个命令。做一个ls /bin/[
或ls /usr/bin/[
。你会看到它实际上是一个可执行文件。
[...]
是从旧的Bourne贝壳天。 if
命令执行该语句,并且如果该语句的退出代码为零,则该语句被视为true并执行if子句。如果退出代码不为零,则执行else子句(如果存在)。
尝试这些:
$ date
Fri May 18 00:04:03 EDT 2012
echo $? #Prints the exit code of the date command
0
$ date -Q #Shouldn't work, I hope...
date: illegal option -- q
usage: date [-jnu] [-d dst] [-r seconds] [-t west] [-v[+|-]val[ymwdHMS]] ...
[-f fmt date | [[[mm]dd]HH]MM[[cc]yy][.ss]] [+format]
$ echo $? #Exit code for the date command
1
你可以看到date
是一个有效的命令,并返回退出代码0(的$?
的值),但date -Q
是无效的,并返回退出代码1.
现在让我们尝试他们在if
声明:
if date
then
echo "I've successfully printed out the date!"
else
echo "I made a mistake in the command"
fi
现在试试这个:
if date -q
then
echo "I've successfully printed out the date!"
else
echo "I made a mistake in the command"
fi
最初,[...]
是为test
命令的别名。以下是等价的:
if test -f /bin/ls #Does a file called /bin/ls exist?
then
echo "There's a /bin/ls file"
fi
和
if [ -f /bin/ls ]
then
echo "There's a /bin/ls file"
fi
这就是为什么把[
和]
周围的空间是非常重要的。因为这些实际上是命令。在BASH中,内置于shell中,但它们是命令。这也是为什么所有测试参数(如-f
,-z
和-eq
)都以破折号作为前缀的原因。它们最初是test
命令的参数。对于算术比较
使用所述支架和所述参数
$ cat x
#!/bin/bash
if [ "$1" == "0" ]; then
echo "good"
else
echo "bad"
fi
$ bash x 0
good
:)
使用双括号,那么你就不需要担心报价和间距,例如:
#!/bin/bash
if (($1 == 0)); then
echo "good"
else
echo "bad"
fi
一般规则:使用(())
用于算法和[[ ]]
文字和图案。正如其他人所说,[是旧的Bourne shell语法,并且几乎没有什么理由再使用它。
你说的是实话... –
哇,谢谢你提供的信息。我认为这只是bash语法的一部分。 – imMAW
它是一部分,不是bash语法的一部分。这是一个内置的命令,如'read'或'echo'。这些也现在被构建到shell中,但可执行文件仍然存在于/ bin或者/ usr/bin目录中。 –
它现在是bash中的一个内置命令,但它仍然只是'test'的同义词,而不是语法。 – chepner