grep 一个文件,但显示周围的几行?
-
08-06-2019 - |
题
我想 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 行
在“/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
笔记:代替 a
和 b
具有前后行数的变量。
对于不支持 grep 的系统特别有用 -A
, -B
和 -C
参数。