我想要 grep
对于一个字符串,还显示前五行和后五行以及匹配的行。我怎么能这样做?
我想要 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
上下文)。
ACK 使用与grep类似的参数,并接受 -C
。但搜索代码通常更好。
grep astring myfile -A 5 -B 5
这将为“astring”grep“myfile”,并在每次匹配之前和之后显示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的正则表达式引擎 这非常 高效 关于大数据。
这里是 @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
注意:替换 a
和 b
具有前后行数的变量。
它对于不支持grep的系统特别有用 -A
, -B
和 -C
参数。