search - windows tail download




grep一個文件,但顯示幾個周圍的行? (6)

ripgrep

如果您關心性能,請使用與grep具有相似語法的ripgrep ,例如

rg -C5 "pattern" .

-C , - --context NUM - 在每次匹配前後顯示NUM行。

還有一些參數,例如-A / --after-context-B / --before-context

該工具建立在Rust的正則表達式引擎之上,使其在大數據上非常efficient

我想grep一個字符串,但也顯示前五行和以下五行以及匹配的行。 我怎麼能這樣做?


ack使用與grep類似的參數,並接受-C 。 但搜索代碼通常更好。


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

我通常使用

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

許多像grep這樣的工具也有很棒的man文件。 我發現自己經常提到grep的手冊頁,因為你可以用它做很多事情。

man grep

許多GNU工具還有一個信息頁面 ,除了手冊頁之外,它還可能包含更多有用的信息。

info grep

這是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變量替換a前後行數。

它對於不支持grep的-A-B-C參數的系統特別有用。







command-line-interface