3

我正在尝试在这样的while循环中使用进程替换的标准输出:

#!/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")

完美运行,当我将数据添加到文件中时,我可以在终端上看到输出。

是否需要使用一些特殊语法才能将标准输出通过管道传输到另一个进程?

我试过做

paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...

但它仍然只是坐在终端上。

4

2 回答 2

5

当 stdout 不是终端时,paste将缓冲其输出。您的命令有效,它只需要在任何事情发生之前进行一定量的输入。

要立即获得输出,您可以使用以下命令取消缓冲标准输出stdbuf

stdbuf -oL paste <(tail -f "$FILE_1") <(tail -f "$FILE_2") | while read LINE; do...
于 2015-04-07T05:33:48.553 回答
0

我相信你有两个主要问题。第一个是您需要结合使用此处的字符串命令替换以及进程替换来完成您想要的重定向。例如:

while read LINE
do 
    echo "$LINE"
done <<< "$( paste <( tail -2 "$FILE_1" ) <( tail -2 "$FILE_1" ) )"

上面的命令工作正常。但是,请注意,上面的命令使用一组可确定的行,FILE_1FILE_2通过使用tail(例如tail -2)的封闭形式。我认为您不能follow在这种情况下使用该选项。我正在寻找,但还没有找到规则为什么。使用--serial粘贴选项没有区别。

于 2015-04-07T05:05:20.400 回答