Compartilhar via


Get-Host

Obtém um objeto que representa o programa host atual.

Sintaxe

Get-Host []

Description

O Get-Host cmdlet obtém um objeto que representa o programa que está hospedando o Windows PowerShell.

A exibição padrão inclui o número da versão do Windows PowerShell e a região e as configurações de idioma atuais usadas pelo host, mas o objeto de host contém uma grande quantidade de informações, inclusive informações detalhadas sobre a versão do Windows PowerShell que está sendo executada e a cultura atual e a cultura da interface do usuário do Windows PowerShell. Você também pode usar esse cmdlet para personalizar os recursos da interface de usuário do programa host, como as cores de plano de fundo e texto.

Exemplos

Exemplo 1: Obter informações sobre o host do console do PowerShell

Get-Host

Name             : ConsoleHost
Version          : 2.0
InstanceId       : e4e0ab54-cc5e-4261-9117-4081f20ce7a2
UI               : System.Management.Automation.Internal.Host.InternalHostUserInterface
CurrentCulture   : en-US
CurrentUICulture : en-US
PrivateData      : Microsoft.PowerShell.ConsoleHost+ConsoleColorProxy
IsRunspacePushed : False
Runspace         : System.Management.Automation.Runspaces.LocalRunspace

Esse comando exibe informações sobre o console do PowerShell, que é o programa host atual do PowerShell neste exemplo. Ele inclui o nome do host, a versão do PowerShell que está sendo executada no host e a cultura atual e a cultura da interface do usuário.

As propriedades Version, UI, CurrentCulture, CurrentUICulture, PrivateData e Runspace contêm um objeto com outras propriedades úteis. Exemplos posteriores examinam essas propriedades.

Exemplo 2: Redimensionar a janela do PowerShell

$H = Get-Host
$Win = $H.UI.RawUI.WindowSize
$Win.Height = 10
$Win.Width  = 10
$H.UI.RawUI.Set_WindowSize($Win)

Esse comando redimensiona a janela do Windows PowerShell para 10 linhas por 10 caracteres.

Exemplo 3: Obter a versão do PowerShell para o host

(Get-Host).Version

Major  Minor  Build  Revision
-----  -----  -----  --------
5      1      22621  963

Este comando obtém informações detalhadas sobre a versão do Windows PowerShell em execução no host. Você pode exibir, mas não alterar, esses valores.

A propriedade Version de Get-Host contém um objeto System.Version . Esse comando usa um operador de pipeline (|) para enviar o objeto de versão para o Format-List cmdlet. O Format-List comando usa o parâmetro Property com um valor de all (*) para exibir todas as propriedades e valores de propriedade do objeto de versão.

Exemplo 4: Obter a cultura atual do host

(Get-Host).CurrentCulture | Format-List

Parent                         : en
LCID                           : 1033
KeyboardLayoutId               : 1033
Name                           : en-US
IetfLanguageTag                : en-US
DisplayName                    : English (United States)
NativeName                     : English (United States)
EnglishName                    : English (United States)
TwoLetterISOLanguageName       : en
ThreeLetterISOLanguageName     : eng
ThreeLetterWindowsLanguageName : ENU
CompareInfo                    : CompareInfo - en-US
TextInfo                       : TextInfo - en-US
IsNeutralCulture               : False
CultureTypes                   : SpecificCultures, InstalledWin32Cultures
NumberFormat                   : System.Globalization.NumberFormatInfo
DateTimeFormat                 : System.Globalization.DateTimeFormatInfo
Calendar                       : System.Globalization.GregorianCalendar
OptionalCalendars              : {System.Globalization.GregorianCalendar}
UseUserOverride                : True
IsReadOnly                     : True

Este comando obtém informações detalhadas sobre a cultura atual definida para o Windows PowerShell em execução no host. Essas são as mesmas informações retornadas Get-Culture pelo cmdlet.

Da mesma forma, a propriedade CurrentUICulture retorna o mesmo objeto que Get-UICulture retorna.

A propriedade CurrentCulture do objeto host contém um objeto System.Globalization.CultureInfo . Esse comando usa um operador de pipeline (|) para enviar o objeto CultureInfo para o Format-List cmdlet. O Format-List comando usa o parâmetro Property com um valor de all (*) para exibir todas as propriedades e valores de propriedade do objeto CultureInfo .

Exemplo 5: Obter o DateTimeFormat para a cultura atual

(Get-Host).CurrentCulture.DateTimeFormat | Format-List

AMDesignator                     : AM
Calendar                         : System.Globalization.GregorianCalendar
DateSeparator                    : /
FirstDayOfWeek                   : Sunday
CalendarWeekRule                 : FirstDay
FullDateTimePattern              : dddd, MMMM dd, yyyy h:mm:ss tt
LongDatePattern                  : dddd, MMMM dd, yyyy
LongTimePattern                  : h:mm:ss tt
MonthDayPattern                  : MMMM dd
PMDesignator                     : PM
RFC1123Pattern                   : ddd, dd MMM yyyy HH':'mm':'ss 'GMT'
ShortDatePattern                 : M/d/yyyy
ShortTimePattern                 : h:mm tt
SortableDateTimePattern          : yyyy'-'MM'-'dd'T'HH':'mm':'ss
TimeSeparator                    : :
UniversalSortableDateTimePattern : yyyy'-'MM'-'dd HH':'mm':'ss'Z'
YearMonthPattern                 : MMMM, yyyy
AbbreviatedDayNames              : {Sun, Mon, Tue, Wed...}
ShortestDayNames                 : {Su, Mo, Tu, We...}
DayNames                         : {Sunday, Monday, Tuesday, Wednesday...}
AbbreviatedMonthNames            : {Jan, Feb, Mar, Apr...}
MonthNames                       : {January, February, March, April...}
IsReadOnly                       : False
NativeCalendarName               : Gregorian Calendar
AbbreviatedMonthGenitiveNames    : {Jan, Feb, Mar, Apr...}
MonthGenitiveNames               : {January, February, March, April...}

Este comando retorna informações detalhadas sobre o DateTimeFormat da cultura atual que está sendo usada para o Windows PowerShell.

A propriedade CurrentCulture do objeto host contém um objeto CultureInfo que, por sua vez, tem muitas propriedades úteis. Entre eles, a propriedade DateTimeFormat contém um objeto DateTimeFormatInfo com muitas propriedades úteis.

Para localizar o tipo de um objeto armazenado em uma propriedade de objeto, use o Get-Member cmdlet. Para exibir os valores de propriedade do objeto, use o Format-List cmdlet.

Exemplo 6: Obter a propriedade RawUI para o host

Esse comando exibe as propriedades da propriedade RawUI do objeto host. Ao alterar esses valores, você pode alterar a aparência do programa host.

(Get-Host).UI.RawUI

ForegroundColor       : Gray
BackgroundColor       : Black
CursorPosition        : 0,28
WindowPosition        : 0,0
CursorSize            : 25
BufferSize            : 120,29
WindowSize            : 120,29
MaxWindowSize         : 120,29
MaxPhysicalWindowSize : 1904,69
KeyAvailable          : True
WindowTitle           : PowerShell 7.3.3

Exemplo 7: Definir a cor da tela de fundo para o console do PowerShell

Estes comandos alteram a cor de plano de fundo do console do Windows PowerShell para preto. O Clear-Host comando limpa a tela para redefinir a janela do console para a nova cor.

(Get-Host).UI.RawUI.BackgroundColor = "Black"
Clear-Host

Essa alteração entra em vigor somente na sessão atual. Para alterar a cor da tela de fundo do console para todas as sessões, adicione o comando ao seu perfil do PowerShell.

Exemplo 8: Definir a cor da tela de fundo para mensagens de erro

$Host.PrivateData.ErrorBackgroundColor = "white"

Este comando altera a cor de plano de fundo das mensagens de erro para branco.

Esse comando usa a $Host variável automática, que contém o objeto host para o programa host atual. Get-Host retorna o mesmo objeto que contém, para que $Host você possa usá-los de forma intercambiável.

Esse comando usa a propriedade PrivateData de $Host como sua propriedade ErrorBackgroundColor. Para ver todas as propriedades do objeto no $Host. PrivateData, digite $host.PrivateData | format-list *.

Entradas

None

Você não pode canalizar objetos para esse cmdlet.

Saídas

System.Management.Automation.Internal.Host.InternalHost

Esse cmdlet retorna um objeto InternalHost .

Observações

A $Host variável automática contém o mesmo objeto que Get-Host retorna e você pode usá-la da mesma maneira. Da mesma forma, as $PSCulture variáveis e $PSUICulture automatic contêm os mesmos objetos que as propriedades CurrentCulture e CurrentUICulture do objeto host contêm. Você pode usar esses recursos alternadamente.

Para obter mais informações, confira about_Automatic_Variables.