Get-Host
Ruft ein Objekt ab, das das aktuelle Hostprogramm darstellt.
Syntax
Get-Host []
Beschreibung
Das Get-Host
Cmdlet ruft ein Objekt ab, das das Programm darstellt, das Windows PowerShell hostet.
Die Standardanzeige umfasst die Windows PowerShell-Versionsnummer und die aktuellen Regions- und Spracheinstellungen des Hosts. Das Hostobjekt enthält jedoch zahlreiche Informationen, darunter detaillierte Angaben zur ausgeführten Windows PowerShell-Version und der aktuellen Kultur und Benutzeroberflächenkultur von Windows PowerShell. Mit diesem Cmdlet können auch Funktionen der Benutzeroberfläche des Hostprogramms angepasst werden, wie z. B. die Farben für Text und Hintergrund.
Beispiele
Beispiel 1: Abrufen von Informationen zum PowerShell-Konsolenhost
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
Dieser Befehl zeigt Informationen zur PowerShell-Konsole an, bei der es sich um das aktuelle Hostprogramm für PowerShell in diesem Beispiel handelt. Sie enthält den Namen des Hosts, die Version von PowerShell, die auf dem Host ausgeführt wird, sowie die aktuelle Kultur und Benutzeroberflächenkultur.
Die Eigenschaften Version, UI, CurrentCulture, CurrentUICulture, PrivateData und Runspace enthalten jeweils ein Objekt mit anderen nützlichen Eigenschaften. In späteren Beispielen werden diese Eigenschaften erläutert.
Beispiel 2: Ändern der Größe des PowerShell-Fensters
$H = Get-Host
$Win = $H.UI.RawUI.WindowSize
$Win.Height = 10
$Win.Width = 10
$H.UI.RawUI.Set_WindowSize($Win)
Mit diesem Befehl wird die Größe des Windows PowerShell-Fensters auf 10 Zeilen um 10 Zeichen geändert.
Beispiel 3: Abrufen der PowerShell-Version für den Host
(Get-Host).Version
Major Minor Build Revision
----- ----- ----- --------
5 1 22621 963
Dieser Befehl ruft detaillierte Informationen über die Version von Windows PowerShell ab, die auf dem Host ausgeführt wird. Sie können diese Werte anzeigen, aber nicht ändern.
Die Version-Eigenschaft enthält Get-Host
ein System.Version-Objekt . Dieser Befehl verwendet einen Pipelineoperator (|
), um das Versionsobjekt an das Format-List
Cmdlet zu senden. Der Format-List
Befehl verwendet den Parameter Property mit einem Wert aller (*
) zum Anzeigen aller Eigenschaften und Eigenschaftswerte des Versionsobjekts.
Beispiel 4: Abrufen der aktuellen Kultur für den 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
Dieser Befehl ruft detaillierte Informationen über die aktuelle Kultur der auf dem Host ausgeführten Windows PowerShell-Version ab. Dies sind die gleichen Informationen, die Get-Culture
vom Cmdlet zurückgegeben werden.
Entsprechend gibt die CurrentUICulture-Eigenschaft dasselbe Objekt zurück, das Get-UICulture
zurückgegeben wird.
Die CurrentCulture-Eigenschaft des Hostobjekts enthält ein System.Globalization.CultureInfo -Objekt. Dieser Befehl verwendet einen Pipelineoperator (|
), um das CultureInfo-Objekt an das Format-List
Cmdlet zu senden. Der Format-List
Befehl verwendet den Parameter Property mit einem Wert aller (*
) zum Anzeigen aller Eigenschaften und Eigenschaftswerte des CultureInfo-Objekts .
Beispiel 5: Abrufen des DateTimeFormat für die aktuelle Kultur
(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...}
Dieser Befehl gibt detaillierte Informationen zu DateTimeFormat der aktuellen Kultur zurück, die für Windows PowerShell verwendet wird.
Die CurrentCulture-Eigenschaft des Hostobjekts enthält ein CultureInfo-Objekt , das wiederum viele nützliche Eigenschaften aufweist. Darunter enthält die DateTimeFormat-Eigenschaft ein DateTimeFormatInfo -Objekt mit vielen nützlichen Eigenschaften.
Verwenden Sie das Get-Member
Cmdlet, um den Typ eines Objekts zu finden, das in einer Objekteigenschaft gespeichert ist. Verwenden Sie das Format-List
Cmdlet, um die Eigenschaftswerte des Objekts anzuzeigen.
Beispiel 6: Abrufen der RawUI-Eigenschaft für den Host
Mit diesem Befehl werden die Eigenschaften der RawUI-Eigenschaft des Hostobjekts angezeigt. Durch das Ändern dieser Werte können Sie die Darstellung des Hostprogramms ändern.
(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
Beispiel 7: Festlegen der Hintergrundfarbe für die PowerShell-Konsole
Diese Befehle ändern die Hintergrundfarbe der Windows PowerShell-Konsole in Schwarz. Mit Clear-Host
dem Befehl wird der Bildschirm gelöscht, um das Konsolenfenster auf die neue Farbe zurückzusetzen.
(Get-Host).UI.RawUI.BackgroundColor = "Black"
Clear-Host
Diese Änderung gilt nur in der aktuellen Sitzung. Um die Hintergrundfarbe der Konsole für alle Sitzungen zu ändern, fügen Sie dem PowerShell-Profil den Befehl hinzu.
Beispiel 8: Festlegen der Hintergrundfarbe für Fehlermeldungen
$Host.PrivateData.ErrorBackgroundColor = "white"
Dieser Befehl ändert die Hintergrundfarbe von Fehlermeldungen in Weiß.
Dieser Befehl verwendet die $Host
automatische Variable, die das Hostobjekt für das aktuelle Hostprogramm enthält. Get-Host
gibt dasselbe Objekt zurück, das $Host
enthalten ist, sodass Sie sie austauschbar verwenden können.
Dieser Befehl verwendet die PrivateData-Eigenschaft $Host
als ErrorBackgroundColor-Eigenschaft. So zeigen Sie alle Eigenschaften des Objekts in der $Host
. PrivateData-Eigenschaft, Typ $host.PrivateData | format-list *
.
Eingaben
None
Sie können keine Objekte an dieses Cmdlet weiterleiten.
Ausgaben
System.Management.Automation.Internal.Host.InternalHost
Dieses Cmdlet gibt ein InternalHost-Objekt zurück.
Hinweise
Die $Host
automatische Variable enthält dasselbe Objekt, das Get-Host
zurückgegeben wird, und Sie können sie auf die gleiche Weise verwenden. Ebenso enthalten die $PSCulture
und $PSUICulture
die automatischen Variablen dieselben Objekte wie die CurrentCulture- und CurrentUICulture-Eigenschaften des Hostobjekts. Diese Funktionen sind austauschbar.
Weitere Informationen finden Sie unter about_Automatic_Variables.