我如何在每一条匹配的线周围显示前面和后面的5条线?


当前回答

这是awk中的@Ygor解决方案

awk 'c-->0;$0~s{if(b)for(c=b+1;c>1;c--)print r[(NR-c+1)%b];print;c=a}b{r[NR%b]=$0}' b=3 a=3 s="pattern" myfile

注意:用前后的行数替换a和b变量。

它对于不支持grep的-A、-B和-C参数的系统特别有用。

其他回答

里普雷普

如果您关心性能,请使用与grep语法相似的ripgrep,例如。

rg -C5 "pattern" .

-C、 --context NUM—在每次匹配前后显示NUM行。

还有一些参数,如-A/-after上下文和-B/-before上下文。

该工具构建在Rust的正则表达式引擎之上,这使得它对大数据非常有效。

使用grep

$ grep --help | grep -i context
Context control:
  -B, --before-context=NUM  print NUM lines of leading context
  -A, --after-context=NUM   print NUM lines of trailing context
  -C, --context=NUM         print NUM lines of output context
  -NUM                      same as --context=NUM

我采用紧凑的方式:

grep -5 string file

这相当于:

grep -A 5 -B 5 string file
$ grep thestring thefile -5

-5会让你在匹配项上下各5行,“thestring”相当于-C 5或-A 5-B 5。

对于BSD或GNUgrep,可以使用-B num设置匹配前的行数,使用-A num设置匹配后的行数。

grep -B 3 -A 2 foo README.txt

如果希望前后行数相同,可以使用-C num。

grep -C 3 foo README.txt

这将显示前3行和后3行。