我正在尝试比较两个变量之间的时间差。 $dt
是从日志文件文本中提取的字符串。 $curtime
是从当前日期和时间中提取的。
如果我输出$dt
,它会正确显示日志文件中的日期和时间。 如果我输出$curtime
,它会正确显示工作站的日期和时间。
但是当我尝试运行New-TimeSpan
并输出差异时,我的响应始终是"02:24:12"。
这是我正在使用的代码:
New-TimeSpan $dt $curtime | Set-Variable -Name $TimeDiff
if ($TimeDiff.Seconds -lt 0) }
$Hrs = ($TimeDiff.Hours) + 23
$Mins = ($TimeDiff.Minutes) + 59
$Secs = ($TimeDiff.Seconds) + 59 }
else {
$Hrs = $TimeDiff.Hours
$Mins = $TimeDiff.Minutes
$Secs = $TimeDiff.Seconds }
$Difference = '{0:00}:{1:00}:{2:00}' -f $Hrs,$Mins,$Secs
$Difference
除非他从日志中的日期时间来自非常狭窄的时间跨度,
通过添加 23:59:59 来操纵 IMO 毫无意义。
最好从 中获取整数部分。总小时数
这里返回时间>24/99
$dt = "05/26/19 08:23:37"
$LogDT = [datetime]::parseexact($dt,"MM/dd/yy HH:mm:ss",[cultureInfo]::Invariantculture)
$TimeDiff = [datetime]::now - $LogDT
$Difference = '{0:00}:{1:00}:{2:00}' -f ([math]::floor($Timediff.TotalHours)),
$Timediff.Minutes,$Timediff.Seconds
示例输出:
> $Difference
111:16:17