您在此部分中有多个错误:
`$(cat B)`
您正在混合两个命令替换. $(cat B)
是同义词`cat B`
所以你在这里所拥有的实际上相当于$($(cat B))
.换句话说,取B的内容并将其用作命令,然后替换该命令的输出.
此外,因为您在命令周围使用双引号,所以在解析命令时评估此构造,而不是在执行时评估.你可以通过反斜杠逃避美元符号来防止这种情况.
此外,您需要转义${CHECK_VALUE}
以防止shell在计算字符串时插入它,就像命令替换一样.我还建议引用该值,除非您希望它包含一个令牌(甚至可能只是为了您自己的理智).
最后,你&&
后面没有任何东西.这是语法错误.
这是我的修复脚本:
docker run --rm \ /bin/bash -c "\ su - hello && \ echo \"Pre\" && \ python ${M} ${F} ${D} ${B} && \ echo \"Post\" && \ CHECK_VALUE=\"\$(cat B)\" && \ echo \"\${CHECK_VALUE}\""
我还在cat
其输出包含shell元字符的情况下添加了引号.
...虽然捕获变量只是为了你可以echo
它是一个反模式 ; 可能你只想cat ${B}
作为最后的命令.
如果你希望su - hello
导致后续 命令运行hello
,那也是错误的(虽然是一个常见的新手错误). su
生成一个新的shell,当该shell 终止时(不在它内部),将执行以下命令.你可能意味着su -c "python $M $F $D $B" hello && cat "$B"
简单明了.将它包装在docker
命令行中,试试吧
docker run --rm \ /bin/bash -c "su -c 'python $M $F $D $B' hello && cat $B"
单引号不会阻止变量插值,因为在双引号内,它们实际上并没有引用任何东西(比较echo "don't"
显然撇号会有问题,如果实际上它有引用语义).
您在此部分中有多个错误:
`$(cat B)`
您正在混合两个命令替换. $(cat B)
是同义词`cat B`
所以你在这里所拥有的实际上相当于$($(cat B))
.换句话说,取B的内容并将其用作命令,然后替换该命令的输出.
此外,因为您在命令周围使用双引号,所以在解析命令时评估此构造,而不是在执行时评估.你可以通过反斜杠逃避美元符号来防止这种情况.
此外,您需要转义${CHECK_VALUE}
以防止shell在计算字符串时插入它,就像命令替换一样.我还建议引用该值,除非您希望它包含一个令牌(甚至可能只是为了您自己的理智).
最后,你&&
后面没有任何东西.这是语法错误.
这是我的修复脚本:
docker run --rm \ /bin/bash -c "\ su - hello && \ echo \"Pre\" && \ python ${M} ${F} ${D} ${B} && \ echo \"Post\" && \ CHECK_VALUE=\"\$(cat B)\" && \ echo \"\${CHECK_VALUE}\""
我还在cat
其输出包含shell元字符的情况下添加了引号.
...虽然捕获变量只是为了你可以echo
它是一个反模式 ; 可能你只想cat ${B}
作为最后的命令.
如果你希望su - hello
导致后续 命令运行hello
,那也是错误的(虽然是一个常见的新手错误). su
生成一个新的shell,当该shell 终止时(不在它内部),将执行以下命令.你可能意味着su -c "python $M $F $D $B" hello && cat "$B"
简单明了.将它包装在docker
命令行中,试试吧
docker run --rm \ /bin/bash -c "su -c 'python $M $F $D $B' hello && cat $B"
单引号不会阻止变量插值,因为在双引号内,它们实际上并没有引用任何东西(比较echo "don't"
显然撇号会有问题,如果实际上它有引用语义).