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

#!/bin/bash

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

echo $MOREF

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

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


当前回答

还有两种方法:

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

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

其他回答

正如他们已经向您指出的那样,您应该使用“倒勾”。

提议的另一种$(命令)也很有效,而且它也更容易阅读,但请注意,它仅适用于Bash或KornShell(以及由此派生的shell),因此,如果您的脚本必须在各种Unix系统上真正可移植,那么您应该更喜欢旧的backticks表示法。

只是为了与众不同:

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

当设置一个变量时,确保在=符号之前和/或之后没有空格。我真的花了一个小时试图找出这个问题,尝试了各种解决方案!这不酷。

对的:

WTFF=`echo "stuff"`
echo "Example: $WTFF"

将失败,出现错误“stuff:not found”或类似错误

WTFF= `echo "stuff"`
echo "Example: $WTFF"

我知道三种方法:

功能适用于此类任务:**函数(){ls-l}通过说func来调用它。还可以评估另一种合适的解决方案:var=“ls-l”评估$var第三种是直接使用变量:var=$(ls-l)或var=`ls-l`

您可以很好地获得第三个解决方案的输出:

echo "$var"

而且以一种令人讨厌的方式:

echo $var

有些人可能觉得这很有用。变量替换中的整数值,技巧是使用$(())双括号:

N=3
M=3
COUNT=$N-1
ARR[0]=3
ARR[1]=2
ARR[2]=4
ARR[3]=1

while (( COUNT < ${#ARR[@]} ))
do
  ARR[$COUNT]=$((ARR[COUNT]*M))
  (( COUNT=$COUNT+$N ))
done