PowerShell显示已用时间

Jef*_*eff 19 powershell timer

我有一个脚本启动一个事件,并等待用户按任意键来停止脚本执行.我正在尝试找到一种方法来显示一个计时器(脚本运行了多长时间),同时在Read-Host上等待用户输入.有没有办法实现这个目标?


这有效

$Time = [System.Diagnostics.Stopwatch]::StartNew()
while ($true) {
    $CurrentTime = $Time.Elapsed
    write-host $([string]::Format("`rTime: {0:d2}:{1:d2}:{2:d2}",
                                  $CurrentTime.hours,
                                  $CurrentTime.minutes,
                                  $CurrentTime.seconds)) -nonewline
    sleep 1
    if ($Host.UI.RawUI.KeyAvailable -and ("q" -eq $Host.UI.RawUI.ReadKey("IncludeKeyUp,NoEcho").Character)) {
        Write-Host "Exiting now"
        break;
    }
}
Run Code Online (Sandbox Code Playgroud)

xel*_*o52 16

从文章测量Powershell中的经过时间(存档副本):

假设变量$script:StartTime是在脚本的开头设置的,可以使用以下任一方法确定已用时间:

$elapsedTime = new-timespan $script:StartTime $(get-date)

要么

$elapsedTime = $(get-date) - $script:StartTime

两种方法的工作方式完全相同,并生成一个System.TimeSpan对象.

因此,使用上面的示例,您可以$script:StartTime在Read-Host之前设置然后再调用 $elapsedTime = $(get-date) - $script:StartTime.


小智 9

这给了我以后的输出:)

$StartTime = $(get-date)

$elapsedTime = $(get-date) - $StartTime

$totalTime = "{0:HH:mm:ss}" -f ([datetime]$elapsedTime.Ticks)
Run Code Online (Sandbox Code Playgroud)


Swe*_*ete 6

使用计时器类(RIP poshtips)给了我这样的东西:

$Time = [System.Diagnostics.Stopwatch]::StartNew()
while ($NoEvent) {
    $CurrentTime = $Time.Elapsed
    write-host $([string]::Format("`rTime: {0:d2}:{1:d2}:{2:d2}",
                                  $CurrentTime.hours,
                                  $CurrentTime.minutes,
                                  $CurrentTime.seconds)) -nonewline
    sleep 1

    #Handle event
    if(event){$NoEvent = false}
}
Run Code Online (Sandbox Code Playgroud)

$ NoEvent是你的事件/布尔值(键按func等).

  • Diagnostics.stopwatch 有问题,fwiw (2认同)

Cli*_*ard 5

我很高兴从 Xelco52 的答案中扩展了这个小功能

$startTime = $(get-date)
write-host "Elapsed:00:00:00"
$NoEvent = $true
While ($NoEvent)
{
  Start-Sleep 1
  $elapsedTime = new-timespan $startTime $(get-date)
  write-host "Elapsed:$($elapsedTime.ToString("hh\:mm\:ss"))"  

  #Handle event
  if(event){$NoEvent = $false} 
}
Run Code Online (Sandbox Code Playgroud)