我在bash (3.00) shell脚本中有一大堆关于变量的测试,如果变量没有设置,那么它会分配一个默认值,例如:

if [ -z "${VARIABLE}" ]; then 
    FOO='default'
else 
    FOO=${VARIABLE}
fi

我似乎记得在一行中做这件事有一些语法,类似于三元运算符,例如:

FOO=${ ${VARIABLE} : 'default' }

(虽然我知道这行不通……)

是我疯了吗,还是真的有这样的东西存在?


当前回答

对于命令行参数:

VARIABLE="${1:-$DEFAULTVALUE}"

它将传递给脚本的第一个参数的值赋给VARIABLE,如果没有传递这样的参数,则将DEFAULTVALUE的值赋给VARIABLE。引用可以防止词缀和分词。

其他回答

回答你的问题和所有变量替换

echo "${var}"
echo "Substitute the value of var."
    

echo "${var:-word}"
echo "If var is null or unset, word is substituted for var. The value of var does not change."
    

echo "${var:=word}"
echo "If var is null or unset, var is set to the value of word."
    

echo "${var:?message}"
echo "If var is null or unset, message is printed to standard error. This checks that variables are set correctly."
    

echo "${var:+word}"
echo "If var is set, word is substituted for var. The value of var does not change."

您可以通过在美元符号和表达式的其余部分之间放置\来转义整个表达式。

echo "$\{var}"

FWIW,你可以像这样提供一个错误消息:

USERNAME=${1:?"Specify a username"}

这将显示如下消息,并以代码1退出:

./myscript.sh
./myscript.sh: line 2: 1: Specify a username

一个更完整的例子:

#!/bin/bash
ACTION=${1:?"Specify 'action' as argv[1]"}
DIRNAME=${2:-$PWD}
OUTPUT_DIR=${3:-${HOMEDIR:-"/tmp"}}

echo "$ACTION"
echo "$DIRNAME"
echo "$OUTPUT_DIR"

输出:

$ ./script.sh foo
foo
/path/to/pwd
/tmp

$ export HOMEDIR=/home/myuser
$ ./script.sh foo
foo
/path/to/pwd
/home/myuser

$ACTION接受第一个参数的值,如果为空则退出 $DIRNAME是第二个参数,默认为当前目录 $OUTPUT_DIR是第三个参数,或者$HOMEDIR(如果有定义),else, /tmp。这适用于OS X,但我不确定它是否可移植。

参见这里的3.5.3(shell参数展开)

所以在你的案例中

${VARIABLE:-default}

你甚至可以使用其他变量的默认值

有一个文件defvalue.sh

#!/bin/bash
variable1=$1
variable2=${2:-$variable1}

echo $variable1
echo $variable2

执行./ value.sh first-value - second-value output

first-value
second-value

执行./ value.sh first-value output

first-value
first-value

如果变量相同,则

: "${VARIABLE:=DEFAULT_VALUE}"

如果没有定义,则将DEFAULT_VALUE赋值给VARIABLE。

内置冒号(:)确保不执行变量结果 双引号(")可以防止通配符和分词。

参见Bash手册中的章节3.5.3,Shell参数扩展。