Bash 中如何捕获标准错误到一个变量 ?

在 Bash 中,您可以使用 2>&1 操作符和 $() 命令替换语法将命令的标准错误输出存储到一个变量中。这里 2>&1 将错误消息重定向到 &1 (标准输出)。默认情况下,shell 作为标准输出设备。
例如,要将 ls 命令的标准错误输出存储到名为 errors 的变量中,可以使用以下命令:
errors=$(ls non-existent-file 2>&1)

或者,您可以使用 $? 特殊参数,将命令的退出状态存储到一个变量中。退出状态是一个数字值,指示命令是否成功。值“0”表示成功,而非“0”表示错误。
例如,要将 ls 命令的退出状态存储到一个名为 status 的变量中,可以使用以下命令:
ls non-existent-file
status=$?
然后可以使用 $status 变量检查 ls 命令的退出状态,并根据结果采取适当的操作。例如:
ls non-existent-file
status=$?
if [ $status -ne 0 ]; then
echo "Last command failed with an error."
fi
请记住,$() 命令替换语法允许您执行命令并替换其输出。 2> 操作符将命令的标准错误输出重定向到 &1 标准输出流,这允许您捕获命令的标准输出和标准错误输出到变量中。
我的开源项目
评论已关闭
