grep 一个文件,但显示几行?

我想grep一个字符串,但还要显示前五行和后五行以及匹配的行。我将如何做到这一点?

答案

对于BSDGNU grep您可以使用-B num设置匹配之前的行数,而-A num设置匹配之后的行数。

grep -B 3 -A 2 foo README.txt

如果您希望前后使用相同数量的行,则可以使用-C num

grep -C 3 foo README.txt

这将在前面显示 3 行,在后面显示 3 行。

-A-B将起作用, -C n (对于n行上下文)或-n (对于n行上下文... 只要 n 为 1 到 9)都将起作用。

ack使用与 grep 类似的参数,并接受-C 。但是通常通过代码搜索会更好。

grep astring myfile -A 5 -B 5

将 grep“myfile” 替换为 “astring”,并在每次匹配之前和之后显示 5 行

我通常使用

grep searchstring file -C n # n for number of lines of context up and down

许多工具(例如 grep)也具有非常好的 man 文件。我发现自己经常参考grep 的手册页,因为您可以做很多事情。

man grep

许多 GNU 工具还具有一个信息页面 ,该信息页面除手册页面外可能还有更多有用的信息。

info grep

使用 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

在 “/some/file.txt” 中搜索 “17655”,以显示前后 10 行的上下文(使用 Awk),并在输出前添加行号和冒号。当'grep' 不支持 “-[ACB]” 选项时,在 Solaris 上使用此选项。

awk '

/17655/ {
        for (i = (b + 1) % 10; i != b; i = (i + 1) % 10) {
                print before[i]
        }
        print (NR ":" ($0))
        a = 10
}

a-- > 0 {
        print (NR ":" ($0))
}

{
        before[b] = (NR ":" ($0))
        b = (b + 1) % 10
}' /some/file.txt;

ripgrep

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

rg -C5 "pattern" .

-C ,-- --context NUM在每次匹配之前和之后显示 NUM 行。

还有一些参数,例如-A / --after-context-B / --before-context

该工具建立在Rust 的正则表达式引擎之上,这使其在大数据上非常高效

这是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

注意:用前后的行数替换ab变量。

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

$ grep thestring thefile -5

-5使您在匹配 “thestring” 上方和下方的5行等效于-C 5-A 5 -B 5