perl切割日誌的利器

來源:互聯網
上載者:User

用了過awk,python,perl都切過日誌,還是感覺perl是切日誌的高手,執行效率高,功能也足夠強大。下面是一個小例子:
open(FILE,"/data/ebi/meta/log");
open(CONF,"/data/ebi/conf/urltype.txt");
open(LOG,">/data/ebi/meta/log_2");
@array1=();
while(<CONF>) {
         chomp;
         @array2 = split(/,/, $_);
         if(scalar(@array2)>=6){
                push @array1,[@array2];
         } 
}

close(CONF);

while(<FILE>)
{
  chomp;
  my ($suv,$times,$ip,$url,$refer,$type1) = split(/\s+/, $_);
  $type=$type1;
  my (undef,undef,$site) = split(/\//, $url);
  if($urlsitemap{$url}){
         $site = $urlsitemap{$url}[0]; 
         $prod = $urlsitemap{$url}[1];
         $fun = $urlsitemap{$url}[2];
  }
  else{
          for $i (0 .. $#array1){  
                $regx = @{$array1[$i]}[1];  
                if($url=~/$regx/){
                        $site = @{$array1[$i]}[2]; 
                        $prod = @{$array1[$i]}[3];
                        $fun = @{$array1[$i]}[4];
                        $urlsitemap{$url}=[$site,$prod,$fun];
                        last;
                }
          } 
  }

print LOG "$site $suv $ip $url $refer,$type\n ";

}

close(FILE);

close(LOG);

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.