我正在尝试比较两个变量之间的时间差。 $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
答案 0 :(得分:0)
除非日志中的日期时间是非常短的时间范围,
通过添加23:59:59来操作IMO毫无意义。
最好取.TotalHours
返回时间> 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