我想 grep 对于字符串,还显示前五行和后五行以及匹配的行。我怎样才能做到这一点?

有帮助吗?

解决方案

为了 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 行。

其他提示

-A-B 会起作用,也会的 -C n (为了 n 上下文线),或者只是 -n (为了 n 上下文线...只要n是1到9)。

确认 使用与 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

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

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

ripgrep

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

rg -C5 "pattern" .

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

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

该工具构建于 Rust 的正则表达式引擎 这使得它非常 高效的 关于大数据。

$grep thestring thefile -5

-5让您在比赛“ thestring”上方和下方的5行等同于-c 5或-a -a 5 -b 5

Grep 有一个选项叫做 Context Line Control, ,您可以使用 --contect 简单地说,

| grep -C 5

或者

| grep -5

应该做的伎俩

这里是 @Ygor解决方案awk

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 参数。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top