Linux运维进阶-Python,Docker,Shell

sed与awk处理区间匹配的笔记--2

2020-04-13  本文已影响0人  My熊猫眼

上一篇中主要对sed的区间匹配中的两个命令n, b做了比较详细的记录;利用这两条命令从而实现区间匹配中的包含问题. 从而可以实现类似如下的匹配结果:

[root@www ~]#  seq 10|  sed -n '/3/,/6/{/6/b;p}'
3
4
5
[root@www ~]# seq 10|  sed -n '/3/,/6/{/3/n;p}'
4
5
6
[root@www ~]# seq 10|  sed -n '/3/,/6/p'
3
4
5
6
[root@www ~]# seq 10|  sed -n '/3/,/6/{/3/n;/6/b;p}'
4
5
[root@www ~]# 

在实际的工作中,查找日志是很频繁的事情,典型的按照时间去查找,比如查找10:00之后,到下午3:00之前的日志(包含10:00的日志,也包含15:00之前的日志),这时候可以分成两段来实现,用sed '/10:00/,/15:00/p' 来打印10:00 到 15:00之间的日志,但是15:00的日志仅仅就包含了一条,所以 第二段用 sed '/15:00/p' 来提取,把两段提取写入一个命令就可以了,如下的一个示例:

[root@www log]# sed -n '/13:15/p' messages | wc -l 
3
[root@www log]# sed -n '/10:01/,/13:15/p' messages | wc -l 
9528
[root@www log]# sed -n '/10:01/,/13:15/p;/13:15/p' messages | wc -l 
9531
[root@www log]# 

除了sed 命令,对文本处理常用的另一个命令是awk, 我们也可以用awk 来处理区间匹配的问题, 示例如下,不过个人更喜欢用sed 来进行区间匹配:

[root@www log]# seq 100 | awk '/88/,/91/{if(i>1)print x;x=$0;i++}' 
89
90
[root@www log]#

本文原创,转载请著名出处

上一篇下一篇

猜你喜欢

热点阅读