目前我们有一个共享软件,该脚本的目的是收集每个用户的所有使用时间。为此,我希望按用户查找日志文件并获取记录运行时间的行,并将其添加到每个用户的最终编号。
在循环中,为每个userid获取所有与时间相关的行并保存在一个变量中。
my $output = `find / -name "$userID" -print0 | xargs -0 grep 'running time' ` ;
$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秒。
答案 0 :(得分:2)
my $secs = 0;
while ($output =~ /running time\s+(?:(\d+):)?(\d+(?:\.\d+)?)/g) {
$secs += $1*60 if $1;
$secs += $2;
}