zoukankan      html  css  js  c++  java
  • perl的logwrapper

    来源:

    http://www.cnblogs.com/itech/archive/2012/09/22/2698385.html

    对任何的函数将标准输出和错误输出重定向到对应的log文件。

    对任何的函数记录函数运行的时间。

    代码:

     1 #!/usr/bin/perl
     2 use warnings;
     3 use strict;
     4 no strict "refs";
     5 
     6 sub testLogToStd{
     7 print "Test stdout : 
    ";
     8 open LOG,"> 2.txt";
     9 select LOG;
    10 print "just a test
    ";
    11 #recover STDOUT
    12 select STDOUT;
    13 print "just a test2
    ";
    14 close LOG;
    15 }
    16 
    17 sub testFun{
    18   print "From testFun
    ";
    19   print STDERR "From TestFun Error
    ";
    20 }
    21 sub testFun2{
    22   my $arg1 = shift;
    23   my $arg2 = shift;
    24   print "From testFun2
    ";
    25   print $arg1."
    ";
    26   print $arg2."
    ";
    27 }
    28 
    29 my $log_root = "log" if(! $3 ||$3 == "");
    30 my $ret = system("mkdir $log_root") if(! -e $log_root);
    31 my $report_log = "$log_root/report.log";
    32 open my $REPORTLOG,">",$report_log or die "cannot not open log file report.log
    ";
    33 
    34 sub logWrapper{
    35   my $log_root = shift;
    36   my $REPORTLOG  = shift;
    37   my $fun = shift;
    38   my @parameters = @_;
    39   *old_stdout = *STDOUT;
    40   *old_stderr = *STDERR;
    41   open LOG, ">","$log_root/$fun.log" or die "annot open log file $fun.
    ";
    42   *STDOUT = *LOG;
    43   *STDERR = *LOG;
    44   my $start = time;
    45   my $ret = &$fun(@parameters);
    46   my $end = time;
    47   *STDOUT = *old_stdout;
    48   *STDERR = *old_stderr;
    49   close LOG;
    50 
    51   my $duration = $end - $start;
    52   print $REPORTLOG "$fun
    ";
    53   print $REPORTLOG "start:".localtime($start)."
    ";
    54   print $REPORTLOG "end:".localtime($end)."
    ";
    55   print $REPORTLOG "duration:".formatTimeDuration($duration)."
    ";
    56   print $REPORTLOG "result:$ret
    ";
    57   print $REPORTLOG "
    ";
    58   print $REPORTLOG "
    ";
    59 }
    60 
    61 sub formatTimeDuration($){
    62   my $t = shift;
    63   my $hrs = int($t/3600);
    64   my $mins = int($t%3600/60);
    65   my $secs = int($t%3600%60);
    66   return "$hrs:$mins:$secs";
    67 }
    68 
    69 
    70 &logWrapper($log_root,$REPORTLOG,"testFun");
    71 &logWrapper($log_root,$REPORTLOG,"testFun2","arg1","arg2");

    print "thanks "; 

    如果需要调用外部命令需要如下:

     1 use strict;
     2 use warnings;
     3 
     4 # run external commands
     5 # redirect stdout and stderr
     6 sub run_cmd{
     7   my $cmd = shift;
     8   my $pid = open(PH, "$cmd 2>&1 |");
     9   while (<PH>) {print $_; }
    10 }
    11 
    12 open(FH, ">", "perl-test.log");
    13 *old_stdout = *STDOUT;
    14 *old_stderr = *STDERR;
    15 *STDOUT = *FH;
    16 *STDERR = *FH;
    17 my $ret = undef;
    18 $ret = readpipe("cp a b ");
    19 $ret = system("cp a b");
    20 $ret = `cp a b`;
    21 run_cmd("cp a b");
    22 print "AA";
    23 print STDERR "BB";
    24 *STDOUT = *old_stdout;
    25 *STDERR = *old_stderr;
  • 相关阅读:
    [引]Windows窗体编程基础学习: 对话框组件
    UML学习四:UML在微软的VS与Visio间的应用 VEA(Visio for Enterprise Architects)
    SQL查询 FOR XML [RAW|AUTO|EXPLICIT]
    微软企业类库:Enterprise Library for .NET Framework 2.0 January 2006
    自定义制作 自动定时更换图片的桌面背景 html页面
    [引]Windows Server 2003 : Windows 群集
    LOVE
    SQL Server Mobile 学习(三):SQL Server Mobile 远程数据访问(RDA)
    游戏分类
    [摘]UML学习二:标准建模语言UML的静态建模机制
  • 原文地址:https://www.cnblogs.com/spriteflk/p/5741099.html
Copyright © 2011-2022 走看看