【问题标题】:awk print "matched" after successful match匹配成功后 awk 打印“匹配”
【发布时间】:2020-06-05 04:37:02
【问题描述】:

尝试使用 awk 搜索文件中的特定行,如果匹配,则在打印每一行后写入“匹配”。

例如,如果我有一个包含姓名和电子邮件列表的文件,但我只想匹配以“@yahoo.com”结尾的电子邮件,我希望它打印出最后带有“matched”的那一行,并且如果该行不包含@yahoo.com,我只想让它打印出该行并继续。

awk -F, '{if($3~/yahoo.com/){ print $1,$2,$3 " matched"}else{ print $1,$2,$3 }}' emails.txt

这会返回:

Joe Smith joe.smith@yahoo.com matched
John Doe john.doe@gmail.com 
Sally Sue sally.sue@yahoo.com`

所以它只匹配第一个@yahoo.com,然后打印其他行,不管他们的电子邮件地址是什么。我错过了什么?

【问题讨论】:

  • 在请求帮助编写脚本来解析文件内容时,最重要的是向我们展示文件的内容。到目前为止,您已经向我们展示了您运行的脚本及其产生的输出 - 添加您运行它的输入文件,以便我们可以帮助您找出您的脚本出错的地方。还要添加预期的输出,因为是否要打印不匹配的行并不完全清楚。文本听起来像您没有,但是您的脚本确实如此,如果输出中只有匹配的行,为什么还要添加“匹配”。因此,请向我们展示示例输入和预期输出。
  • 您测试第三个字段(逗号分隔符)。我假设“Sally Sue”记录有任何与逗号相关的问题。最好的是,您在此处提供文件emails.txt 以供进一步分析。

标签: bash awk


【解决方案1】:

请您尝试关注一下。

awk '/@yahoo\.com/{print $0,"matched"}' Input_file

说明:您显示的示例 Input_file 没有逗号,因此从其中删除了该字段分隔符部分。

另外一个人的名字可以有两个以上的字段,所以我不匹配条件中的第三个字段,而是在这里检查整行的条件。

【讨论】:

    【解决方案2】:

    这可能就是你想要的:

    awk -F, '{print $0 ($NF ~ /@yahoo\.com$/ ? " matched" : "")}' emails.txt
    

    但没有看到您的输入文件,这只是未经测试的猜测。

    【讨论】:

      【解决方案3】:

      我使用以下输入测试了示例:给定的文件分隔符是,在您的示例中,拆分后您可以访问 $3 记录(电子邮件)并匹配您的条件。

      输入:

      Joe,Smith,joe.smith@yahoo.com
      John,Doe,john.doe@gmail.com
      Sally,Sue,sally.sue@yahoo.com```
      

      脚本

      awk -F, '{if($3~/yahoo.com/){ print $1,$2,$3 " matched"}else{ print $1,$2,$3 }}' emails.txt
      

      输出:

      Joe Smith joe.smith@yahoo.com matched
      John Doe john.doe@gmail.com 
      Sally Sue sally.sue@yahoo.com matched
      

      【讨论】:

        【解决方案4】:

        如果该行以 @yahoo.com 结尾,则将整行重新分配为自身,后跟字符串 matched

        awk '/@yahoo.com$/{$0=$0 " matched"}1' input
        
        Joe Smith joe.smith@yahoo.com matched
        John Doe john.doe@gmail.com
        Sally Sue sally.sue@yahoo.com matched
        

        【讨论】: