运行此代码时:
while true; do printf "Match Unmatch\n"; sleep 1s; done | grep -o "Match"
在终端中,grep
找到单词Match
. 我得到输出:
Match
Match
Match
...
但是,当我运行以下代码时:
while true; do printf "Match Unmatch"; sleep 1s; done | grep -o "Match"
然后grep
似乎什么也没找到,至少它什么也没打印。grep 是否在等待永远不会出现的换行符?是否有某种方法可以在没有换行符的情况下在流中进行 grep、sed 或类似工具捕获匹配?
Grep 主要查找包含与给定模式匹配的行。根据模式,在不查看整行的情况下可能会或可能无法确定一行是否匹配。有了
grep Match
,这是可能的,但有了grep 'Match$'
,就不行了。使用, grep 可以在看到它时立即grep -o Match
打印,但是使用,如果 grep 已经读取,它不知道是否会跟随。Match
grep -E -o '(Match)+'
MatchMa
tch
Grep 没有实现在看到整行之前可以写一些输出的特殊情况。(我认为它没有实现任何这种特殊情况,但我不完全确定:GNU grep 有几种模式,具体取决于行为方式有所不同。)它在尝试匹配之前只读取一整行。
如果有一个字符从未出现在匹配文本中,并且总是(或至少经常)出现在匹配之间,则将此字符转换为换行符。(或者变成一个空字节并使用
grep -z
。)注意使用
stdbuf -o0
以防止tr
缓冲其输出。如果你通过管道输出 grep 的输出,你也需要 grep 的输出,或者使用grep --line-buffered
. (--line-buffered
缓冲 grep 的输出;它对 grep 读取输入的方式没有影响,并且当 grep 打印到终端时默认开启。)