Condividi tramite


Get-FormatData

Ottiene i dati di formattazione della sessione corrente.

Sintassi

Get-FormatData
   [[-TypeName] <String[]>]
   [-PowerShellVersion <Version>]
   [<CommonParameters>]

Descrizione

Il Get-FormatData cmdlet ottiene i dati di formattazione nella sessione corrente.

I dati di formattazione nella sessione includono la formattazione dei dati dai Format.ps1xml file di formattazione, ad esempio quelli nella $PSHOME directory, la formattazione dei dati per i moduli importati nella sessione e la formattazione dei dati per i comandi importati nella sessione usando il Import-PSSession cmdlet .

È possibile usare questo cmdlet per esaminare i dati di formattazione. È quindi possibile usare il Export-FormatData cmdlet per serializzare gli oggetti, convertirli in XML e salvarli nei Format.ps1xml file.

Per altre informazioni sulla formattazione dei file in PowerShell, vedere about_Format.ps1xml.

Esempio

Esempio 1: Ottenere tutti i dati di formattazione

In questo esempio vengono visualizzati tutti i dati di formattazione nella sessione.

Get-FormatData

Esempio 2: Ottenere dati di formattazione in base al nome del tipo

Questo esempio ottiene gli elementi di dati di formattazione i cui nomi iniziano con System.Management.Automation.Cmd.

Get-FormatData -TypeName 'System.Management.Automation.Cmd*'

Esempio 3: Esaminare un oggetto dati di formattazione

Questo esempio illustra come ottenere un oggetto dati di formattazione ed esaminarne le proprietà.

$F = Get-FormatData -TypeName 'System.Management.Automation.Cmd*'
$F

TypeName        FormatViewDefinition
--------        --------------------
HelpInfoShort   {help , TableControl}

$F.FormatViewDefinition[0].control

Headers          : {System.Management.Automation.TableControlColumnHeader,
                   System.Management.Automation.TableControlColumnHeader,
                   System.Management.Automation.TableControlColumnHeader,
                   System.Management.Automation.TableControlColumnHeader}
Rows             : {System.Management.Automation.TableControlRow}
AutoSize         : False
HideTableHeaders : False
GroupBy          :
OutOfBand        : False

$F.FormatViewDefinition[0].control.Headers

Label       Alignment Width
-----       --------- -----
CommandType Undefined    15
Name        Undefined    50
Version     Undefined    10
Source      Undefined     0

Esempio 4: Ottenere dati di formattazione ed esportarli

In questo esempio viene illustrato come usare Get-FormatData ed Export-FormatData esportare i dati di formattazione aggiunti da un modulo.

$A = Get-FormatData
Import-Module bitstransfer
$B = Get-FormatData
Compare-Object $A $B

InputObject                                                SideIndicator
-----------                                                -------------
Microsoft.BackgroundIntelligentTransfer.Management.BitsJob =>

Get-FormatData *bits* | Export-FormatData -FilePath c:\test\bits.format.ps1xml
Get-Content c:\test\bits.format.ps1xml

<?xml version="1.0" encoding="utf-8"?><Configuration><ViewDefinitions>
<View><Name>Microsoft.BackgroundIntelligentTransfer.Management.BitsJob</Name>
...

I primi quattro comandi usano i Get-FormatDatacmdlet , Import-Modulee Compare-Object per identificare il tipo di formato aggiunto dal modulo BitsTransfer alla sessione.

Il quinto comando usa il Get-FormatData cmdlet per ottenere il tipo di formato aggiunto dal modulo BitsTransfer . Usa un operatore pipeline (|) per inviare l'oggetto tipo di formato al Export-FormatData cmdlet , che lo converte di nuovo in XML e lo salva nel file specificato format.ps1xml .

Il comando finale mostra un estratto del contenuto del format.ps1xml file.

Esempio 5: Ottenere dati di formattazione in base alla versione specificata di PowerShell

Questo esempio illustra come usare Get-FormatData per ottenere dati di formato per una versione di TypeName e PowerShell specificata.

Get-FormatData -TypeName 'Microsoft.Powershell.Utility.FileHash' -PowerShellVersion $PSVersionTable.PSVersion

TypeNames                               FormatViewDefinition
---------                               --------------------
{Microsoft.Powershell.Utility.FileHash} {Microsoft.Powershell.Utility.FileHash}

Importante

Per assicurarsi che vengano restituite informazioni complete sulla formattazione del tipo, è necessario includere sempre il parametro PowerShellVersion con la versione appropriata. Se il parametro e il valore vengono omessi, non è possibile ottenere tutte le informazioni sul tipo corrette.

Parametri

-PowerShellVersion

Specificare la versione di PowerShell che questo cmdlet ottiene per i dati di formattazione. Immettere un numero a due cifre separato da un punto.

Questo parametro è stato aggiunto in PowerShell 5.1 per migliorare la compatibilità quando i computer remoti che eseguono versioni precedenti di PowerShell.

Tipo:Version
Posizione:Named
Valore predefinito:None
Necessario:False
Accettare l'input della pipeline:False
Accettare caratteri jolly:False

-TypeName

Specifica i nomi dei tipi che questo cmdlet ottiene per i dati di formattazione. Immettere i nomi dei tipi. I caratteri jolly sono consentiti.

Tipo:String[]
Posizione:0
Valore predefinito:None
Necessario:False
Accettare l'input della pipeline:False
Accettare caratteri jolly:True

Input

None

Non è possibile inviare tramite pipe oggetti a questo cmdlet.

Output

ExtendedTypeDefinition