我在Powershell上花了多少时间?

时间:2018-11-28 23:47:26

标签: powershell stopwatch

使用 $ profile 文件的Powershell,我想找出每次在Powershell上花费多少时间,将其打印到文件中。

例如

24.11.2018, 13:41 -  1 hour 23 minute 12 second
11.11.2018, 13:41 -  2 hour 3 minute 2 second
11.11.2018, 13:41 -  1 hour 43 minute 42 second
...
...

上面显示了名为 ps_time_history.txt 的文件的内容。 我打开了Powershell屏幕3次,并显示了打开电源的时间。

我编写了如下脚本,但无法获得所需的解决方案。

我已按如下所示在 $ profile 文件中编写了一个脚本,但无法以所需的方式获得解决方案。

Start-Job  -scriptblock 
{ 
  $StopWatch = New-Object -TypeName System.Diagnostics.Stopwatch
  $StopWatch.Start();

  $date=((Get-Process -Name powershell | Sort-Object StartTime | where { $_ }).StartTime | Select -Last 1);
  $id=((Get-Process -Name powershell | Sort-Object StartTime | where { $_  }).id | select -Last 1 );


  while ($StopWatch.IsRunning)
   {
      Start-Sleep -Seconds 1
      if((Get-Process -id $id -ErrorAction SilentlyContinue))
      {
        $time=[string]$StopWatch.Elapsed.Hours+":"+[string]$StopWatch.Elapsed.Minutes+":"+[string]$StopWatch.Elapsed.Seconds;
        echo  ([string]$date+" - "+$time) >> ~\Desktop\ps_time_history.txt;
      }
      else
      {  
       $StopWatch.Stop();
      }
   }
 }

我得到了最近打开的powershell应用程序的日期和ID号。 只要打开Powershell屏幕,计时器就会运行。 关闭Powershell屏幕时,计时器需要停止。

我正在编写的脚本每秒执行一次 ps_time_history.txt 文件。 但是我不想要那个。 让Powershell写下关闭时花了多少时间。

11/29/2018 02:23:17 - 0: 0: 1
11/29/2018 02:23:17 - 0: 0: 2
11/29/2018 02:23:17 - 0: 0: 3
11/29/2018 02:23:17 - 0: 0: 4
11/29/2018 02:23:17 - 0: 0: 5
11/29/2018 02:23:17 - 0: 0: 6
11/29/2018 02:23:17 - 0: 0: 7
11/29/2018 02:23:17 - 0: 0: 8
11/29/2018 02:23:17 - 0: 0: 9
11/29/2018 02:23:17 - 0: 0: 10
11/29/2018 02:23:17 - 0: 0: 11
11/29/2018 02:23:17 - 0: 0: 12
11/29/2018 02:23:17 - 0: 0: 13

这个问题似乎有点复杂。 我该如何解决这个问题,或者有更短的方法?

2 个答案:

答案 0 :(得分:2)

考虑到您想以秒精度记录会话持续时间,而不是弄乱Stopwatch,我认为只需存储会话开始时间并从那里计算持续时间就足够了... < / p>

$sessionStartTime = Get-Date;

两者之间的差异可以忽略不计,但是,如果您不是要从会话变为“可用”时开始计算,而是要从流程开始时开始计算,则可以使用$PID automatic variable获取PowerShell流程实例并保存其实例。 StartTime属性...

$sessionStartTime = Get-Process -Id $PID | Select-Object -ExpandProperty 'StartTime';

此完整的$PROFILE脚本对我有用,它在会话结束时使用Exiting engine event运行ScriptBlock

[DateTime] $sessionStartTime = Get-Date;

Register-EngineEvent `
    -SourceIdentifier ([System.Management.Automation.PsEngineEvent]::Exiting) `
    -SupportEvent `
    -Action {
        [DateTime] $sessionExitTime = Get-Date;
        [TimeSpan] $sessionDuration = $sessionExitTime - $sessionStartTime;
        [String] $logLine = "$sessionExitTime - $sessionDuration";

        $logLine >> '~\Desktop\ps_time_history.txt';
    };

请注意,这仅处理在控制台上键入exit的情况。记录代码未运行when clicking the Close ("X") button on the PowerShell console window

使用DateTimeTimeSpan的默认格式,这将输出:

11/28/2018 18:26:48 - 00:00:03.1026319

如果您不希望持续时间包含小数秒,则可以像这样使用custom TimeSpan formatting ...

[String] $logLine = '{0:d} {0:HH\:mm\:ss} - {1:HH\:mm\:ss}' -f $sessionExitTime, $sessionDuration;

答案 1 :(得分:0)

还有一些内置的事件日志。例如,下面的代码将列出在最近10分钟内启动/退出powershell的时间(但不会捕获带有X按钮的退出)

$filter = @{ LogName='Windows Powershell'; StartTime=(get-date).AddMinutes(-10); EndTime=(Get-Date) } 
 Get-WinEvent -FilterHashtable $filter | Sort-Object TimeCreated | where {$_.id -in 400, 403}