awk,第4列在@之前所有匹配的通配符

rez*_*ter 3 awk

我试图从pmta邮件日志中提取数据.

单个条目看起来如下

b,2013-02-04 03:48:57+0200,2013-02-04 03:48:57+0200,noreply@test.com,fynnb@domain.com,rfc822;fynnb@domain.com,failed,5.3.2 (system not accepting network messages),smtp;550 Too many invalid recipients,mx02.domain.com (146.230.128.12),other,smtp,twww01.test.com(10.0.0.53),,143.37.222.256,146.230.128.12,,,virtmail23,,,domain.com/virtmail23,test-promo,,,,,,,,,,,
Run Code Online (Sandbox Code Playgroud)

有很多条目,我想在第三个逗号之后提取"*@test.com"的条目

目前noreply@test.com在示例中,但我们使用noreply,NoReply,No-Reply和用户,所以我想在@符号之前使用通配符.

到目前为止我所拥有的是什么

awk -F, '$4 == "noreply@test.com"' /home/mail/test.csv
Run Code Online (Sandbox Code Playgroud)

这样可以很好地提取包含"noreply@test.com"的条目,但是如果我使用的话

awk -F, '$4 == "*@test.com"' /home/mail/test.csv
Run Code Online (Sandbox Code Playgroud)

我没有数据.在这个场景中,我可以在awk中使用什么?

Ed *_*ton 8

你需要告诉awk进行RE比较(〜)而不是字符串比较(==):

awk -F, '$4 ~ /@test\.com/' /home/mail/test.csv
Run Code Online (Sandbox Code Playgroud)