初次依葫芦画瓢写bash条件语句时,结果遇到这个错误。这里是条件语句出的错。所以不得不看下bash下编程流程的语法。
错误代码如下:
if [ "${TEST_HOME}"==""] ; then TEST_HOME="${SRC_DIR}/test" fi currentDate=$(date +%Y%m%d%H%M%S) echo $currentDate if [ "$RELEASE_DIR"==""]; then RELEASE_DIR="${SRC_DIR}/release/test${currentDate}" fi
看起来没什么大错,原因出在格式上少了一个空格。在]前面少了一个空格。
bash中if then elif fi条件语句的语法如下:
if 命令; then 命令块 fi 注意: 如果命令的退出状态码是0,则执行命令块,否则跳过命令块。 每条命令执行结束后都会产生一个退出状态码,退出状态码是0-255之间的一个整数值。 bash 脚本通常以命令“exit 数字”结尾,这个“数字”将会作为整个脚本的退出状态码。如果脚本结束时没有遇到该命令,则脚本会以脚本中执行的最后一条命令的退出状态码退出。 可以用命令“echo $?”查看上一条命令的退出状态码。
通常在if中使用命令test,命令test还可以用[ ]代替,如果测试结果为真则退出状态码为0,如果测试结果为假则退出状态码为1。[ ]这种方式对格式有严格的要求:[ ]中每个组件都需要用空格符分隔,[ ]中的变量和常量最好都用双引号引起来。多个[ ]可以使用&&或者||进行逻辑运算,也可以在[ ]内部使用!表示反向状态。
if [ condition ] then action fi 注意:“if”和“[”之间需要空格,如果你不空格,shell会报告语法错误的。 []与里面的表达式与需要空格分开,否则也会报错。
conditon测试类型对照表
运算符 描述 示例 文件比较运算符 -e filename 如果 filename存在,则为真 [ -e /var/log/syslog ] -d filename 如果 filename为目录,则为真 [ -d /tmp/mydir ] -f filename 如果 filename为常规文件,则为真 [ -f /usr/bin/grep ] -L filename 如果 filename为符号链接,则为真 [ -L /usr/bin/grep ] -r filename 如果 filename可读,则为真 [ -r /var/log/syslog ] -w filename 如果 filename可写,则为真 [ -w /var/mytmp.txt ] -x filename 如果 filename可执行,则为真 [ -L /usr/bin/grep ] filename1-nt filename2 如果 filename1比 filename2新,则为真 [ /tmp/install/etc/services -nt /etc/services ] filename1-ot filename2 如果 filename1比 filename2旧,则为真 [ /boot/bzImage -ot arch/i386/boot/bzImage ] 字符串比较运算符 (请注意引号的使用,这是防止空格扰乱代码的好方法) -z string 如果 string长度为零,则为真 [ -z "$myvar" ] -n string 如果 string长度非零,则为真 [ -n "$myvar" ] string1= string2 如果 string1与 string2相同,则为真 [ "$myvar" = "one two three" ] string1!= string2 如果 string1与 string2不同,则为真 [ "$myvar" != "one two three" ] 算术比较运算符 num1-eq num2 等于 [ 3 -eq $mynum ] num1-ne num2 不等于 [ 3 -ne $mynum ] num1-lt num2 小于 [ 3 -lt $mynum ] num1-le num2 小于或等于 [ 3 -le $mynum ] num1-gt num2 大于 [ 3 -gt $mynum ] num1-ge num2 大于或等于 [ 3 -ge $mynum ]