本文转载于: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
.......