我正在尝试在while循环中使用进程替换的stdout,如下所示:
#!/bin/bash
FILE_1=f1.txt
FILE_2=f2.txt
while read LINE; do
echo "$LINE"
done < <(paste <(tail -f "$FILE_1") <(tail -f "$FILE_2"))
每当新数据添加到文件时,它应该做的是合并FILE_1和FILE_2的最后几行。显然,我想做的不仅仅是在while循环中打印行,但这是一个很好的例子。
不幸的是,当我运行这个脚本时,它只是位于终端并且什么都不做。
只运行这一行:
paste <(tail -f "$FILE_1") <(tail -f "$FILE_2")
工作得很好,当我向文件中添加数据时,我可以在终端上看到输出。
为了将stdout传递给另一个进程,我需要使用一些特殊的语法吗?
我已经尝试过了
paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...
但它仍然只是在终端。
答案 0 :(得分:5)
当stdout不是终端时,paste
将缓冲其输出。你的命令有效,在发生任何事情之前只需要一定量的输入。
要立即获得输出,您可以使用stdbuf
:
stdbuf -oL paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...
答案 1 :(得分:0)
我相信你有2个主要问题。首先,您需要结合使用此处字符串,命令替换以及流程替换来完成您想要的重定向。例如:
while read LINE
do
echo "$LINE"
done <<< "$( paste <( tail -2 "$FILE_1" ) <( tail -2 "$FILE_1" ) )"
上面的命令工作正常。但是,注意上面的命令使用FILE_1
和FILE_2
的一系列可确定的行,使用封闭形式的tail
(例如tail -2
)。在这种情况下,我认为您不能使用follow
选项。我正在寻找,但尚未找到原因。使用--serial
选项进行粘贴没有任何区别。