perl拆分以获取字符串中的时间

时间:2015-06-12 17:31:36

标签: perl split

目前我们有一个共享软件,该脚本的目的是收集每个用户的所有使用时间。为此,我希望按用户查找日志文件并获取记录运行时间的行,并将其添加到每个用户的最终编号。

  1. 代码是用Perl编写的。
  2. 我将所有用户ID保存在一个文件中说userlist
  3. 在循环中,为每个userid获取所有与时间相关的行并保存在一个变量中。

    my $output = `find / -name "$userID" -print0 | xargs -0 grep 'running time' ` ; 
    
  4. $output中的内容如下:

    logPath:Time INFO  [XXX] :user -       running time           1.75 seconds
    logPath:Time INFO  [XXX] :user -       running time           0.34 seconds
    logPath:Time INFO  [XXX] :user -       running time           21.15 seconds
    logPath:Time INFO  [XXX] :user -       running time           43:10.83
    logPath:Time INFO  [XXX] :user -       running time           10:50.77
    

    对我来说,问题是:我应该如何编写分割函数或使用其他方法来总结这些时间? 43:10.83是43分钟和10.83秒。

1 个答案:

答案 0 :(得分:2)

my $secs = 0;
while ($output =~ /running time\s+(?:(\d+):)?(\d+(?:\.\d+)?)/g) {
    $secs += $1*60 if $1;
    $secs += $2;
}