文本处理:在行中间找到一个匹配项,然后在该行之前打印该行

时间:2019-10-03 14:15:35

标签: ksh aix

我想搜索2019年及以后的所有行,但仅在“ To:”字符串之后。 “发件人:”和“收件人:”之间的任何内容都不相关。

我尝试将grep与-A -B选项一起使用,但是AIX上的grep没有该选项。 我也尝试过类似的方法,但是我不知道如何在比赛前打印行,以及如何在行中间搜索模式。

awk'$ 13> = 2019 {print $ 0}'file.txt

最后,我想在“ To:”字符串后面的每一行中搜索“ 2019”。 例如,输出看起来像这样:

certificate4-从:CEST到2009年10月16日,星期五1:22:18到:CEST到2019年10月16日,星期三1:32:16

1 个答案:

答案 0 :(得分:1)

猜测OP的构想:

  • 如果一行包含字符串“ To:”和
  • 该行在字段#15中也有一个数字,即> = 2019然后
  • 打印上一行和当前行

以及一些假设:

  • 文件中的第一行可能匹配
  • 连续的行可以匹配'To:/> = 2019'搜索:
  • 对于所有感兴趣的行,“ To”位于字段15之前

仅基于OP提供的一行来采样数据:

$ cat -n print15.dat
 1  certificate1 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2019 1:32:16 PM CEST
 2  this is line two
 3  this is line three
 4  certificate4 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2019 1:32:16 PM CEST
 5  this is line five
 6  this is line six
 7  certificate7 - From: Friday, October 16, 2020 1:22:18 PM CEST To: Wednesday, October 16, 2017 1:32:16 PM CEST
 8  this is line eight
 9  this is line nine
10  certificate10 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2020 1:32:16 PM CEST
11  this is line eleven
12  certificate12 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2023 1:32:16 PM CEST
13  certificate13 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2024 1:32:16 PM CEST
14  this is line fourteen

应用所描述的逻辑,我们看到第1、4、10、12和13行与“ To:./> = 2019”匹配。

一种awk解决方案:

$ awk '/To:/ && $15 >= 2019 { printf "\n#############\n"
                              if (length(prevline) > 0) { print prevline }
                              print $0
                              printf   "#############\n"
                            }
                            { prevline=$0 }
' print15.dat

说明:

  • /To:/ && $15 >= 2019:匹配模式为“ To:”且字段#15> = 2019的任何行(当然,这并不强制要求“ To:”出现在字段#15之前)
  • print/########:简单的标题/尾部,以明显区分匹配行集
  • if/length/print:如果prevline不为空,则打印它
  • print $0:打印当前行(与“ To:”和$ 15> = 2019匹配)
  • prevline=$0:将“ prevline”变量设置为当前行(用作我们处理的下一行的“ previous line”)

输出:

#############
certificate1 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2019 1:32:16 PM CEST
#############

#############
this is line three
certificate4 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2019 1:32:16 PM CEST
#############

#############
this is line nine
certificate10 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2020 1:32:16 PM CEST
#############

#############
this is line eleven
certificate12 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2023 1:32:16 PM CEST
#############

#############
certificate12 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2023 1:32:16 PM CEST
certificate13 - From: Friday, October 16, 2009 1:22:18 PM CEST To: Wednesday, October 16, 2024 1:32:16 PM CEST
#############