linux 中实现输出匹配字符之后或之前的若干行

 

001、输出匹配字符之后的若干行

a、

[root@PC1 test4]# ls
a.txt
[root@PC1 test4]# cat a.txt            ## 测试数据
01
02
kk
03
04
05
06
07
kk
08
09
10
11
12                                     ## 输出匹配字符之后的3行
[root@PC1 test4]# awk '$1 == "kk" {print NR}' a.txt | while read i; do sed -n "$i"p a.txt >> result.txt; let temp=$i; for j in $(seq 3); do let temp=$temp+1; sed -n "$temp"p a.txt >> result.txt; done; done
[root@PC1 test4]# ls
a.txt  result.txt
[root@PC1 test4]# cat result.txt   ## 结果文件
kk
03
04
05
kk
08
09
10

 

b、awk + 循环实现

[root@PC1 test4]# ls
a.txt
[root@PC1 test4]# cat a.txt
-1      101
00      102
01      103
02      104
kk      105
03      106
04      107
05      108
06      109
07      110
kk      111
08      112
09      113
10      114
11      115
12      116
[root@PC1 test4]# awk '{if($1 == "kk") {print NR; for(i = 1; i <= 3; i++) {print NR+i}}}' a.txt
5
6
7
8
11
12
13
14
[root@PC1 test4]# awk '{if($1 == "kk") {print NR; for(i = 1; i <= 3; i++) {print NR+i}}}' a.txt | while read i; do awk -v a=$i 'NR == a' a.txt ; done
kk      105
03      106
04      107
05      108
kk      111
08      112
09      113
10      114

 

 

002、输出匹配字符之前的若干行

[root@PC1 test4]# ls
a.txt
[root@PC1 test4]# cat a.txt    ## 测试文件
-1
00
01
02
kk
03
04
05
06
07
kk
08
09
10
11
12                            ## 输出匹配字符之前的3行
[root@PC1 test4]# awk '$1 == "kk" {print NR}' a.txt | while read i; do let temp=$i; for j in $(seq 3 -1 1); do let temp2=$temp-$j; sed -n "$temp2"p a.txt >> result.txt; done; sed -n "$i"p a.txt >> result.txt; done
[root@PC1 test4]# ls
a.txt  result.txt
[root@PC1 test4]# cat result.txt   ## 结果文件
00
01
02
kk
05
06
07
kk

 

awk + 循环实现:

[root@PC1 test4]# ls
a.txt
[root@PC1 test4]# cat a.txt         ## 测试数据
-1      101
00      102
01      103
02      104
kk      105
03      106
04      107
05      108
06      109
07      110
kk      111
08      112
09      113
10      114
11      115
12      116
[root@PC1 test4]# awk '{if($1 == "kk") {for(i = 3; i >= 1; i--) {print NR-i};print NR}}' a.txt
2
3
4
5
8
9
10
11                                                    ## 输出匹配字符之前的3行
[root@PC1 test4]# awk '{if($1 == "kk") {for(i = 3; i >= 1; i--) {print NR-i};print NR}}' a.txt | while read i; do sed -n "$i"p a.txt; done
00      102
01      103
02      104
kk      105
05      108
06      109
07      110
kk      111

 

posted @ 2023-06-04 00:23  小鲨鱼2018  阅读(129)  评论(0编辑  收藏  举报