繁体   English   中英

具有新换行符的Powershell格式表在列之间增加了额外的空间

[英]Powershell Format-Table with new line break adds extra space between column

我在Windows中有2个计划任务:StartAppPool和StopAppPool。

在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                                                  

有人知道我该如何解决吗?

尝试使用Trim方法,如下所示:

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

您也可以尝试为Format-Table cmdlet添加-AutoSize开关

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM