0

Windowsでは2つのスケジュール済みタスク、StartAppPoolとStopAppPoolがあります。Powershell Format-Tableで改行が追加され、列間に余分なスペースが追加されます

StartAppPoolにはジョブトリガーが1つしかありません。 StopAppPoolには2つのジョブトリガーがあります。

スケジュールされたタスクと関連するプロパティのステータスを表示できるスクリプトを作成しようとしています。

Write-Host "9. Checking Task Scheduler Execution Status...." -BackgroundColor DarkCyan 
$taskService = New-Object -ComObject "Schedule.Service" 
$taskService.Connect($env:COMPUTERNAME) 
$rootTaskFolder = $taskService.GetFolder('\') 
$tasks = $rootTaskFolder.GetTasks(1) | Where-Object { $_.Name -in 'StopAppPool','StartAppPool' } 

$TaskArray = @() 
ForEach ($task in $tasks) { 
    $object = New-Object -TypeName PSObject 
    $object | Add-Member -Name 'Name' -MemberType Noteproperty -Value $task.Name 
    $object | Add-Member -Name 'TaskEnabled' -MemberType Noteproperty -Value $task.Enabled 
    $object | Add-Member -Name 'LastRunTime' -MemberType Noteproperty -Value $task.LastRunTime 
    $object | Add-Member -Name 'NextRunTime' -MemberType Noteproperty -Value $task.NextRunTime 

    $TaskXMLObject = [xml]$task.Xml 
    $CalendarTriggers = $TaskXMLObject.Task.Triggers.CalendarTrigger 


    $TaskTriggerArray = @() 
    ForEach ($CalendarTrigger in $CalendarTriggers) { 
     $object2 = New-Object -TypeName PSObject 
     $object2 | Add-Member -Name 'StartBoundary' -MemberType Noteproperty -Value (Get-Date $CalendarTrigger.StartBoundary.Replace('T',' ') -Format "dd/MM/yyyy hh:mm:ss tt") 
     $object2 | Add-Member -Name 'Enabled' -MemberType Noteproperty -Value $CalendarTrigger.Enabled 
     $DaysOfWeek = ($CalendarTrigger.ScheduleByWeek.DaysOfWeek | Get-Member -MemberType Property | Select -ExpandProperty Name) | ForEach-Object -Process { [enum]::parse([System.DayOfWeek],$_) } | Sort-Object #parsing the values into an enum will allow the objects to be sorted by day instead of alphabetical order   
     $object2 | Add-Member -Name 'DaysOfWeek' -MemberType Noteproperty -Value ($DaysOfWeek -join ', ') 

     $TaskTriggerArray += $object2 
    } 

    $object | Add-Member -Name 'StartBoundary' -MemberType NoteProperty -Value ($TaskTriggerArray.StartBoundary | Out-String) 
    $object | Add-Member -Name 'TriggerEnabled' -MemberType Noteproperty -Value ($TaskTriggerArray.Enabled | Out-String) 
    $object | Add-Member -Name 'DaysOfWeek' -MemberType Noteproperty -Value ($TaskTriggerArray.DaysOfWeek | Out-String) 
    $TaskArray += $object 

} 

$TaskArray | Format-Table Name, TaskEnabled, LastRunTime, NextRunTime, @{Label='StartBoundary';Expression={(($_.StartBoundary)}}, TriggerEnabled, DaysOfWeek -Wrap 

残念ながら、「StartBoundary」の欄には、背後にある余分なスペースを追加するようだと、私はそれを修正する方法をどのように見つけ出すことができませんでした。ここにサンプル出力があります

Name   TaskEnabled LastRunTime   NextRunTime   StartBoundary         TriggerEnabled DaysOfWeek             
----   ----------- -----------   -----------   -------------         -------------- ----------             
StartAppPool  True 10/2/2017 6:00:00 AM 11/2/2017 6:00:00 AM 29/09/2016 06:00:00 AM       true   Monday, Tuesday, Wednesday, Thursday, Friday, Saturday  

StopAppPool   True 10/2/2017 5:10:01 AM 11/2/2017 5:10:00 AM 29/09/2016 05:10:00 AM       true   Tuesday, Wednesday, Thursday, Friday, Saturday    
                    05/11/2016 10:00:00 AM       true   Saturday             

誰でも私はそれをどのように修正できますか?

答えて

0

このように、トリムメソッドを使用してみてください:

$_.StartBoundary.ToString().Trim() 

あなたはまた、動作するようには思えないフォーマット、表のためレット

+0

-AutoSizeスイッチを追加しようとすることができます。あなたはあなたの側でそれを試すことができる場合、トリミングされたスペースが表示されますか? –

+0

@louisxie、申し訳ありませんが、私は実際に余分なスペースが表示されません。なぜ実際に高度な書式設定を使用していますか?このプロパティは同じようです。余分な幅の書式を使用することがあります。このように@ {Label = 'StartBoundary'; Expression = {$ _。StartBoundary}; Width = 10; Align = 'Center'}、または基本的に-AutoSizeスイッチを追加するだけです。 –

関連する問題