Linux实用脚本3:gawk获取匹配行的前(后)指定行

本文转载于:awk 打印匹配内容之后的指定行

文本源

jwllinux@jwlLinux ~/shell $ cat test.txt
1 aa
2 bb
3 cc
4 dd
5 ee
6 ff
7 gg

需求

         找到4 dd后打印其后面/前面某行(以两行为例)

命令

1. 找匹配行后的第二行

jwllinux@jwlLinux ~/shell $ awk -v line=$(awk '/dd/{print NR}' test.txt) '{if(NR==line+2){print $0}}' test.txt
6 ff

2. 找匹配行前的第二行

jwllinux@jwlLinux ~/shell $ awk -v line=$(awk '/dd/{print NR}' test.txt) '{if(NR==line-2){print $0}}' test.txt
2 bb

分析

         例子中两次使用awk命令将第一次的结果(匹配行的行号)作为变量赋值给line第二次在匹配行的行号上进行偏移,其中NR表示到目前为止记录总数(The total number of input records seen so far.),通过$0打印出整行。

  • 第一次用于找到匹配行的行号。如下:
jwllinux@jwlLinux ~/shell $ awk '/dd/{print NR}' test.txt
4
  • 第二次通过if(NR==line-2)或if(NR==line+2)获取匹配行前(后)两行。

应用

         在某些场景,我们会设计定时任务收集相关内容(如定时通过show global status 收集mysql状态),每次输出的第一行为时戳,后面为具体信息,如下。此时就可以以时戳TS作为匹配行,寻找匹配行后面的某行。

TS 1541425400.004465555 2018-11-05 08:43:20  08:43:20 up  2:21,  1 user,  load average: 0.88, 0.66, 0.54
Variable_name	Value
Aborted_clients	0
Aborted_connects	2
......
TS 1541425520.008315071 2018-11-05 08:45:20  08:45:20 up  2:23,  1 user,  load average: 0.70, 0.66, 0.56
Variable_name	Value
Aborted_clients	0
Aborted_connects	2
.......

 

你可能感兴趣的:(Linux运维)