我有一个非常简单的脚本,大致如下:
#!/bin/bash
VAR1="$1"
MOREF='sudo run command against $VAR1 | grep name | cut -c7-'
echo $MOREF
当我从命令行运行这个脚本并向它传递参数时,我没有得到任何输出。然而,当我运行$MOREF变量中包含的命令时,我能够获得输出。
如何获取需要在脚本中运行的命令的结果,将其保存到变量中,然后在屏幕上输出该变量?
我有一个非常简单的脚本,大致如下:
#!/bin/bash
VAR1="$1"
MOREF='sudo run command against $VAR1 | grep name | cut -c7-'
echo $MOREF
当我从命令行运行这个脚本并向它传递参数时,我没有得到任何输出。然而,当我运行$MOREF变量中包含的命令时,我能够获得输出。
如何获取需要在脚本中运行的命令的结果,将其保存到变量中,然后在屏幕上输出该变量?
当前回答
Mac/OSX现在有旧的Bash版本,即GNUbash,版本3.2.57(1)-发布(arm64-apple-darwin21)。在这种情况下,可以使用:
new_variable="$(some_command)"
具体示例:
newvar="$(echo $var | tr -d '123')"
注意(),而不是Bash 4中通常的{}。
其他回答
正如他们已经向您指出的那样,您应该使用“倒勾”。
提议的另一种$(命令)也很有效,而且它也更容易阅读,但请注意,它仅适用于Bash或KornShell(以及由此派生的shell),因此,如果您的脚本必须在各种Unix系统上真正可移植,那么您应该更喜欢旧的backticks表示法。
$(sudo run command)
如果你要使用撇号,你需要“,而不是”。此字符称为“背景音”(或“重音符”):
#!/bin/bash
VAR1="$1"
VAR2="$2"
MOREF=`sudo run command against "$VAR1" | grep name | cut -c7-`
echo "$MOREF"
除了反引号“command”之外,还可以使用$(命令)或“$(命令”进行命令替换,我觉得这更容易阅读,并且允许嵌套。
OUTPUT=$(ls -1)
echo "${OUTPUT}"
MULTILINE=$(ls \
-1)
echo "${MULTILINE}"
引号(“)对于保留多行变量值很重要;在赋值的右侧是可选的,因为不执行单词分割,所以OUTPUT=$(ls-1)可以正常工作。
只是为了与众不同:
MOREF=$(sudo run command against $VAR1 | grep name | cut -c7-)
可以使用反引号(也称为重音坟墓)或$()。
喜欢:
OUTPUT=$(x+2);
OUTPUT=`x+2`;
两者都有相同的效果。但是OUTPUT=$(x+2)更可读,并且是最新的。