在bash -c中设置变量

d0x*_*xin 8 linux bash awk ifconfig

我尝试设置从接口IP地址获取的变量,ifconfig然后再读取它.但是当我执行一个echo命令时,变量仍然是空的.请看我的代码:

/usr/bin/bash -c "HOST_IPS=$(/usr/bin/ifconfig | /usr/bin/awk 'BEGIN {cnt=0} {if($0 ~ /inet / && cnt==1) {print $2} cnt++}'); echo $HOST_IPS"
Run Code Online (Sandbox Code Playgroud)

但/ bin/echo使用相同的命令工作正常:

/usr/bin/bash -c "echo $(/usr/bin/ifconfig | /usr/bin/awk 'BEGIN {cnt=0} {if($0 ~ /inet / && cnt==1) {print $2} cnt++}')"
Run Code Online (Sandbox Code Playgroud)

Win*_*ute 7

您必须$在最终的echo命令中转义符号,否则在$HOST_IPS生成子shell之前,该变量将被替换为命令字符串:

/usr/bin/bash -c "HOST_IPS=$(/usr/bin/ifconfig | /usr/bin/awk 'BEGIN {cnt=0} {if($0 ~ /inet / && cnt==1) {print $2} cnt++}'); echo \$HOST_IPS"
Run Code Online (Sandbox Code Playgroud)

为了更直接的可见性:

#                                                  v-- insert backslash here
/usr/bin/bash -c "HOST_IPS=$(same as before); echo \$HOST_IPS"
Run Code Online (Sandbox Code Playgroud)

与@ gniourf_gniourf的评论相反,实际上没有必要逃避其他美元符号.但是,如上所述,命令替换不是由子shell(!)执行的; 其结果将替换为传递给子shell的命令字符串.电话

mypid() { echo $$; }
bash -c "pid=$(mypid); echo \$pid; mypid"
Run Code Online (Sandbox Code Playgroud)

演示它的工作方式:它将一次打印父shell的PID,并且一旦抱怨mypid不是已知的命令,因为子shell不知道该函数.

由于ifconfig | awk在父shell中运行命令不太可能成为问题,因此您可以保持命令替换部分不变.如果命令由子shell运行很重要,那么你也必须逃避所有的事情.