Como eu forço a saída para “Format-Table” para um PSObject personalizado SEM usar um arquivo .format.ps1xml?

0

Eu sei que posso definir a formatação do meu MyCustomPSObject gerando e carregando um arquivo MyCustomPSObject.format.ps1xml .

E eu vi pessoas fazerem essa geração de arquivo de formato on-the-fly de dentro do arquivo de script .ps1 . (Também aqui começando lista abaixo da sentença "Então eu escreveu uma função avançada do PowerShell chamada Get-ProcessTotal " começando na linha 145 .)

E, pelo que entendi, a primeira entrada nesse arquivo de formatação é usada como padrão.

Gerar esse arquivo externo parece complicado para mim.

Pergunta:

  • Existe uma maneira de fazer isso sem gerar e carregar esse arquivo externo?

Tudo que eu quero é "Produzi-lo como uma tabela" . (Basicamente executá-lo através de Format-Table , mas não perdendo a objetividade no processo).

Pergunta relacionada

Script Get-VSSWriters.Current-Version.ps1

Este é o script em questão:

# This script lists VSS writers.
# The original, uncustomized, version was taken from here:
# https://gallery.technet.microsoft.com/scriptcenter/Powershell-ScriptFunction-415e9e70

$RawWriters = Invoke-Command -ErrorAction Stop -ScriptBlock {
    #Requires -RunAsAdministrator 
    return (VssAdmin List Writers)
} 


# We don't really care about "WriterID" and "WriterInstanceID", so we leave them out of the default 
# display set. (Approach copied from here:
# https://learn-powershell.net/2013/08/03/quick-hits-set-the-default-property-display-in-powershell-on-custom-objects/ )
$defaultDisplaySet = 'WriterEnum', 'WriterName', 'StateID', 'StateDesc', 'LastError'
$defaultDisplayPropertySet = New-Object System.Management.Automation.PSPropertySet('DefaultDisplayPropertySet', [string[]]$defaultDisplaySet)
$PSStandardMembers = [System.Management.Automation.PSMemberInfo[]]@($defaultDisplayPropertySet)


$Writers = @()
for ($i=0; $i -lt (($RawWriters.Count)-3)/6; $i++) {
    $Writer = New-Object -TypeName psobject
    $Writer.PSObject.TypeNames.Insert(0, 'MyVSSWriter')
    $Writer | Add-Member MemberSet PSStandardMembers $PSStandardMembers

    $Writer| Add-Member "WriterEnum" ($i + 1)

    # Note: We split on both single quotes and double quotes.
    # That way this script will work for both:
    # * the English language version of Windows (>>Writer name: 'WMI Writer'<<) 
    # * the German version of Windows (>>Verfassername: "WMI Writer"<<)
    $Writer| Add-Member "WriterName" $RawWriters[($i*6)+3].Split("'"'")[1]

    $Writer| Add-Member "WriterID" $RawWriters[($i*6)+4].Split('{}')[1]
    $Writer| Add-Member "WriterInstanceID" $RawWriters[($i*6)+5].Split('{}')[1]

    $Writer| Add-Member "StateID"   $RawWriters[($i*6)+6].Split('[]')[1]
    $Writer| Add-Member "StateDesc" $RawWriters[($i*6)+6].Split('[]')[2].SubString(1)
    $Writer| Add-Member "LastError" $RawWriters[($i*6)+7].Split(':')[1].Substring(1)

    $Writers += $Writer 
}

$Writers

Saída real

PS C:\> .\Get-VSSWriters.Current-Version.ps1 | select -first 1
WriterEnum : 1
WriterName : Task Scheduler Writer
StateID    : 1
StateDesc  : Stable
LastError  : No error

Saída desejada

PS C:\> .\Get-VSSWriters.Updated-Version.ps1 | select -first 1
WriterEnum WriterName            StateID StateDesc LastError
---------- ----------            ------- --------- ---------
         1 Task Scheduler Writer 1       Stable    No error

(que deve ser o mesmo que .\Get-VSSWriters.Current-Version.ps1 | select -first 1 | Format-Table .)

    
por StackzOfZtuff 31.01.2017 / 16:24

1 resposta

0

Tee-Object salva a saída do comando em um arquivo ou variável e também envia para baixo o pipeline.

PS D:\PShell> $x = .\SU\Get-VSSWriters.Current-Version_1173588.ps1
PS D:\PShell> $x | select -First 1 | Tee-Object -Variable y | Format-Table -AutoSize -Wrap

WriterEnum WriterName            StateID StateDesc LastError
---------- ----------            ------- --------- ---------
         1 Task Scheduler Writer 1       Stable    No error


PS D:\PShell> $y.GetType()

IsPublic IsSerial Name                                     BaseType
-------- -------- ----                                     --------
True     False    PSCustomObject                           System.Object


PS D:\PShell> $y


WriterEnum : 1
WriterName : Task Scheduler Writer
StateID    : 1
StateDesc  : Stable
LastError  : No error



PS D:\PShell>
    
por 02.02.2017 / 02:01