如何打印满足条件的多种图案的线条?
例如对于输入文件
部分包含以下内容:
ID : 1
Status : Ok
Name : Lulu
Age : 18
State : US
ID : 2
Status : Ok
Name : Master Yi
Age : 22
State : UK
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA
------------
Codition : IF Age == 20 | print
----------
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA
请帮忙
谢谢
答案1
如果您的文件确实如您所示,并且每条记录之间有 4 个空行,每条记录之间有 3 个空行,那么您可以执行以下操作:
$ awk -v RS='\n\n\n\n' '/Age : 20\n/' file
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA
您还没有澄清这一点,但我怀疑额外的空行实际上并不是文件的一部分,而只是问题格式的假象,因此记录的每一行之间只有一个空行,并且记录之间只有两个空行每条记录。如果是这样,您的输入文件如下所示:
ID : 1
Status : Ok
Name : Lulu
Age : 18
State : US
ID : 2
Status : Ok
Name : Master Yi
Age : 22
State : UK
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA
如果你的文件确实是这样的,那么你可以这样做:
$ awk -v RS= '/Age : 20\n/' file
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA
答案2
以下方法首先创建一个数组以将字段的标签(名称)映射到其值,让您可以执行当前想要的操作,并在将来轻松地增强它以测试复合条件、打印选择字段、以不同顺序打印字段或者对类型数据执行任何其他操作tag:value
:
$ cat tst.awk
BEGIN { OFS=" : " }
!NF { next }
{
tag = val = $0
sub(/ *:.*/,"",tag)
sub(/[^:]+ *: */,"",val)
if ( !(tag in tag2val) ) {
tags[++numTags] = tag
}
tag2val[tag] = val
}
tag == "State" {
if ( tag2val["Age"] == 20 ) {
for (tagNr=1; tagNr<=numTags; tagNr++) {
tag = tags[tagNr]
val = tag2val[tag]
print tag, val
}
print ""
}
delete tag2val
numTags = 0
}
。
$ awk -f tst.awk file
ID : 3
Status : Ok
Name : Garen
Age : 20
State : CA