bash:将stdout捕获到一个变量,但仍然显示在控制台中

前端之家收集整理的这篇文章主要介绍了bash:将stdout捕获到一个变量,但仍然显示在控制台中前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个bash脚本,调用几个长时间运行的进程。我想捕获这些调用输出到变量的处理原因。但是,因为这些是长时间运行的进程,我想要的rsync调用输出显示在控制台中实时,而不是事实。

为此,我有found一种做的方式,但它依赖于输出文本到/ dev / stderr。我觉得输出到/ dev / stderr不是一个好的做事方式。

VAR1=$(for i in {1..5}; do sleep 1; echo $i; done | tee /dev/stderr)

VAR2=$(rsync -r -t --out-format='%n%L' --delete -s /path/source1/ /path/target1 | tee /dev/stderr)

VAR3=$(rsync -r -t --out-format='%n%L' --delete -s /path/source2/ /path/target2 | tee /dev/stderr)

在上面的示例中,我调用rsync几次,我想看到文件名,因为它们被处理,但最后我仍然希望输出在一个变量,因为我将在以后解析。

有没有一个“更清洁”的方法来完成这个?

如果它有所作为,我使用Ubuntu 12.04,bash 4.2.24。

在你的shell中复制& 1(在我的考试中为5),在subshel​​l中使用& 5(这样你将写入父shell的stdout(& 1)):
exec 5>&1
FF=$(echo aaa|tee >(cat - >&5))
echo $FF

将打印aaa两次,一次是因为subshel​​l中的echo,第二次打印变量的值。

在您的代码中:

exec 5>&1
VAR1=$(for i in {1..5}; do sleep 1; echo $i; done | tee >(cat - >&5))
# use the value of VAR1

猜你在找的Bash相关文章