正则表达式 – 比赛前的单词和行的Grep

前端之家收集整理的这篇文章主要介绍了正则表达式 – 比赛前的单词和行的Grep前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个文本日志文件,其中包含多个这样的条目:

Processing input.jpg (323 of 500)...
Detecting matches in region 1...
Detecting matches in region 2...
Detecting matches in region 3...
Detecting matches in region 4...
Detecting matches in region (n)...
...
NOT ENOUGH MATCHES - FULL FILE OUTPUT
Processing input1.jpg (324 of 500)...

我想grep文件以匹配序列FULL FILE出现的每个实例,然后获取生成该结果的文件名称 – 即在每个FULL FILE匹配之前找到开始处理的行.

我怎么能用grep或其他工具如sed或awk这样做?

到目前为止,我能够匹配在日志中找到FULL FILE的每个实例并计算它们:

cat output.txt | grep "FULL FILE" | wc -l

但我现在需要从每个匹配的日志文件获取前面的文件名.

任何帮助非常感谢.

解决方法@H_403_29@
假设文件名中没有空格,awk就可以了

awk '/^Processing/{file=$2};/FULL FILE OUTPUT$/{print file}' output.txt

猜你在找的正则表达式相关文章