我的文本文件如下所示:
bla : 1 - etc
blb : a - etc
blc : 2 - etc
bld : 3 - etc
ble : 1 - etc
blf : 1 - etc
blg : a - etc
blh : 1 - etc
bli : a - etc
我正在文件中搜索模式": 1 -"
。一些连续的线有相同的图案,我需要这两条线加上下一条线。
ble : 1 - etc
blf : 1 - etc
blg : a - etc
是否可以使用grep
、sed
或任何其他工具提取这些行?提前谢谢。
这是一个相当简单的awk:任务
awk -F ' [:-] ' '
$2 == prev2 { # if the 2nd field matches the previous 2nd field,
print prevline # print the previous line
print # print the current line
getline; print # get the next line and print it
}
{prev2 = $2; prevline = $0} # remember these values for the next iteration
' file
我会使用awk
而不是sed
:
awk -F: 'm~$2{print m;print;getline;print}{m=$0}' input.txt
m
是保存最后一行的变量。如果它与:
后面的部分匹配,我们打印m
和当前行,然后获得下一行并打印。最后,CCD_ 9将当前行存储在CCD_ 10中。
Awk比sed更适合像"if"这样的逻辑结构。
$ awk 'substr($0,4,5)==last{print lastline;print;getline;print;} {last=substr($0,4,5);lastline=$0;}' input.txt
ble : 1 - etc
blf : 1 - etc
blg : a - etc
我假设您知道自己需要什么,并且: 1 -
才是您真正想要的,而不是用空格分隔的字段来分割行。如果您的输入数据与您的示例不匹配,请随时更正。
您可以使用egrep:
egrep -A2 ": 1 -" filename
其中A2示出了在找到图案之后的下两条线。
输出:
bla : 1 - etc
blb : a - etc
blc : 2 - etc
--
ble : 1 - etc
blf : 1 - etc
blg : a - etc
blh : 1 - etc
bli : a - etc
是,awk:
awk '/: 1 -/ {++i}
i>1 {print p}
!/: 1 -/ {if(i>1)print;i=0}
{p=$0}
END {if(i>1)print p}'
awk '$1 ~/^bl$|e|f|g/' file
ble : 1 - etc
blf : 1 - etc
blg : a - etc
若第一列以bl开头,以e结尾,则f或g打印这些行。
awk '/: 1 -/ {CNT++; x[CNT]=$0; next} CNT==2 {print x[1]; print x[2]; print $0} {CNT=0}' *.*