我有一个非常简单的脚本,大致如下:

#!/bin/bash

VAR1="$1"
MOREF='sudo run command against $VAR1 | grep name | cut -c7-'

echo $MOREF

当我从命令行运行这个脚本并向它传递参数时,我没有得到任何输出。然而,当我运行$MOREF变量中包含的命令时,我能够获得输出。

如何获取需要在脚本中运行的命令的结果,将其保存到变量中,然后在屏幕上输出该变量?


当前回答

您需要使用

$(此处为命令)

or

`command-here`

实例

#!/bin/bash

VAR1="$1"
VAR2="$2"

MOREF="$(sudo run command against "$VAR1" | grep name | cut -c7-)"

echo "$MOREF"

其他回答

$(sudo run command)

如果你要使用撇号,你需要“,而不是”。此字符称为“背景音”(或“重音符”):

#!/bin/bash

VAR1="$1"
VAR2="$2"

MOREF=`sudo run command against "$VAR1" | grep name | cut -c7-`

echo "$MOREF"

这是另一种方式,很适合与一些无法正确突出显示您创建的每一个复杂代码的文本编辑器一起使用:

read -r -d '' str < <(cat somefile.txt)
echo "${#str}"
echo "$str"

还有两种方法:

请记住,空间在Bash中非常重要。因此,如果要运行命令,请使用原样,而不引入任何空格。

下面将harsil分配给L,然后打印L=$“苛刻”echo“$L”下面将命令tr的输出分配给L2。tr正在对另一个变量L1进行运算。L2=$(echo“$L1”| tr[:上:][:下:])

Mac/OSX现在有旧的Bash版本,即GNUbash,版本3.2.57(1)-发布(arm64-apple-darwin21)。在这种情况下,可以使用:

new_variable="$(some_command)"

具体示例:

newvar="$(echo $var | tr -d '123')"

注意(),而不是Bash 4中通常的{}。

除了反引号“command”之外,还可以使用$(命令)或“$(命令”进行命令替换,我觉得这更容易阅读,并且允许嵌套。

OUTPUT=$(ls -1)
echo "${OUTPUT}"

MULTILINE=$(ls \
   -1)
echo "${MULTILINE}"

引号(“)对于保留多行变量值很重要;在赋值的右侧是可选的,因为不执行单词分割,所以OUTPUT=$(ls-1)可以正常工作。