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

时间:2008-08-12 17:55:33

标签: search logging grep command-line-interface

我想grep表示字符串,但也显示前五行和后五行以及匹配的行。我怎么能这样做?

14 个答案:

答案 0 :(得分:4172)

对于 BSD GNU grep,您可以使用-B num来设置匹配前的行数和-A num比赛结束后的行数。

grep -B 3 -A 2 foo README.txt

如果您希望在使用-C num之前和之后使用相同数量的行。

grep -C 3 foo README.txt

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

答案 1 :(得分:573)

-A-B同样适用-C n(适用于n上下文行),或仅-n(适用于n上下文...只要n是1到9)。

答案 2 :(得分:72)

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

答案 3 :(得分:35)

grep astring myfile -A 5 -B 5

这将为“string”grep“file”,并在每场比赛前后显示5行

答案 4 :(得分:17)

我通常使用

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

许多像grep这样的工具也有很棒的man文件。我发现自己很多都指grep's man page,因为你可以用它做很多事情。

man grep

除了手册页之外,许多GNU工具还有info page可能有更多有用的信息。

info grep

答案 5 :(得分:8)

在“/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;

答案 6 :(得分:7)

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

答案 7 :(得分:3)

ripgrep

如果您关心效果,请使用与grep具有相似语法的ripgrep,例如

rg -C5 "pattern" .
  

-C--context NUM - 在每场比赛前后显示NUM行。

还有-A / --after-context-B / --before-context等参数。

该工具构建于Rust's regex engine之上,这使得它对大数据非常efficient

答案 8 :(得分:1)

$grep thestring thefile -5

-5使您在匹配“ thestring”上下5行相当于-C 5 OR  -A 5 -B 5

答案 9 :(得分:1)

Grep有一个名为Context Line Control的选项,您可以在其中使用--contect

| grep -C 5

| grep -5

应该做到这一点

答案 10 :(得分:1)

您可以在 grep 命令中使用选项 -A(之后)和 -B(之前) 试试 grep -nri -A 5 -B 5 。

答案 11 :(得分:0)

以下是awk

中的@Ygor solution
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参数的系统,它尤其有用。

答案 12 :(得分:0)

我习惯做紧凑的方式

grep -5 string file

相当于

grep -A 5 -B 5 string file

答案 13 :(得分:0)

如果您经常搜索代码,http://text2vec.org/similarity.html比grep效率更高(即更快)。

您可以使用-C选项显示上下文行。

例如:

ag -C 3 "foo" myFile

line 1
line 2
line 3
line that has "foo"
line 5
line 6
line 7