这里有几个问题。
第一个是您试图将变量的内容作为命令执行$ouptut1
,这只是dig
输出;这不是命令。你可能的意思是echo $output1
。
然后,您尝试将变量的内容$grepg
作为管道执行。但是将一行解析为复合命令的组件(管道是复合命令)发生在参数扩展之前。所以如果你执行这样的事情:
foo="echo hello | grep hi"
$foo
首先将其分解为一个简单的命令,然后扩展命令,然后将其解析为参数。所以这相当于运行:
echo hello "|" grep hi
通常,将要评估的文本字符串存储在变量中并不是一个好主意。在一些非常特殊的情况下,您可能想要这样做,但几乎在每种情况下(可能还有您的情况)都有更好的方法来做到这一点。我要警告你不要这样做,但如果你真的想将字符串评估为命令,你可以使用eval
,例如:
go=$(echo $output1 | eval $grepg)
您似乎想要的是定义一个 shell 函数。如果您想多次重用该管道,通过它运行几个不同的值,只需定义一个 shell 函数。该函数是一个单独的命令,相当于包含的命令:
function grepg() {
grep PTR | cut -d ' ' -f 2 | grep google | cut -f 5
}
go=$(echo $output1 | grepg)
为了进一步简化您的代码,您可以避免使用所有中间变量。如果您只是要将dig
命令的结果通过管道传输到grepg
中,则无需在执行此操作之前将其保存在变量中。如果您只是要将结果回显到标准输出,那么您也不需要将其存储在变量中,您可以让输出转到标准输出:
#!/bin/bash
IP=$1
function grepg() {
grep PTR | cut -d ' ' -f 2 | grep google | cut -f 5
}
dig -x $IP | grepg
我在这里假设您想分解该函数,以便可以在脚本中多次使用它;如果没有,如果您只想使用一次,您可以进一步简化为:
#!/bin/bash
IP=$1
dig -x $IP | grep PTR | cut -d ' ' -f 2 | grep google | cut -f 5
请注意,如果您想将这样的管道存储在一个变量中,以便您可以使用其他代码在两个函数之间做出决定,并根据某些条件应用一个或另一个,我建议您定义上述函数,并且然后只需将单个函数名称存储在变量中。这将按您期望的方式工作:
function grepg() {
grep PTR | cut -d ' ' -f 2 | grep google | cut -f 5
}
function grepf() {
# do something else, I'm not creative enough to come up with a good example
}
if [ "$2" = "foo" ]
then
func=grepg
else
func=grepf
fi
dig -x $IP | $func