【问题标题】:grep string and find total no of changes from log file,write in CSV filegrep 字符串并从日志文件中查找更改总数,写入 CSV 文件
【发布时间】:2018-05-13 14:37:14
【问题描述】:

我有一个输入文件(generator_file.log):

[+++]          Added names:          [+++]
     -> Add- response.names (3):
     -> Add- chat.names (2):
     -> Add- events.names (2):
[///]     Modified active rules:     [///]
     -> Mod- events.names (2):
     -> Mod- mal.names (1):
[---]         Removed names:         [---]
     -> Del- chat.names (2):
     -> Del- events.names (8):
     -> Del- jan.names (4):

预期的输出应如下所示:

Add,response,3
Add,chat,2
Add,events,2
Del,chat,2
Del,events,8
Del,jan,4
Total no of Added Names: 7
Total no of Deleted Names: 14

下面是我尝试过但没有得到想要的输出的shell脚本:

egrep "Del-|Add-" generator_file.log |awk '
BEGIN{Addname=0; Delname=0;}
{
      if(match($0,"Add-")>0)
       {
         split($0,addcountb,"(");
         split(addcountb[2], addcount, ")");
         Addname+=addcount[1] ;
       }
     if(match($0,"Del-")>0)
      {
         split($0,delcountb,"(");
         split(delcountb[2], delcount, ")");
         Delname+=delcount[1] ;
      }
}
END {print "Number of names Added: "Addname; print "Number of names Deleted: "Delnames;}'

【问题讨论】:

    标签: shell awk split match


    【解决方案1】:

    awk 来救援!

    $ awk -F' +|[-.()]' -v OFS=, '{c=$(NF-1)} 
                           /Del-/ {del+=c; f=1} 
                           /Add-/ {add+=c; f=1} 
                           f      {print $4,$6,c; f=0} 
                           END    {print "Added: " add; 
                                   print "Deleted: " del}' file
    
    Add,response,3
    Add,chat,2
    Add,events,2
    Del,chat,2
    Del,events,8
    Del,jan,4
    Added: 7
    Deleted: 14
    

    或者可能是

    $ awk -F' +|[-.()]' -v OFS=, '/(Del|Add)-/{c=$(NF-1); cs[$4]+=c;
                                               print $4,$6,c}
                                  END         {print "Added: "   cs["Add"];
                                               print "Deleted: " cs["Del"]}' file
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-01-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多