Sie sind hier:
Lexikon/Glossar
Telefon (Mo-Fr 9-16 Uhr):
0201/649590-0
|
Kontaktformular
MENU
Start
Hauptseite
Angebote im Überblick
Kernkompetenzen
Softwareentwicklung
Beratung
Firmen-Schulungen
Offene Seminare
Online-Maßnahmen
Vorträge
Coaching
Support
Fachbücher
Fachartikel
Konditionen
Themen
Kernkompetenzen
Aktuelle Themen
Web & Cloud
Apps / Mobilplattformen
Benutzeroberflächen / User Experience
.NET
JavaScript / TypeScript
Java
Programmiersprachen
Entwicklungswerkzeuge
Scripting
Softwareengineering
Datenbanken / Reporting / BI
Betriebssysteme & Virtualisierung
Microsoft Server-Produkte
Windows & Office für Anwender
Soft Skills & IT-Recht
Beratung
Beratungsthemen
Coaching
Softwareentwicklung
Technischer Support
Unsere Top-Berater
Referenzkunden
Angebotsanfrage
Individuelle Schulungen
1026 Schulungsthemen
Agendakonfigurator
Weiterbildungsphilosophie
Didaktische Konzepte
Vor Ort oder online
Unsere Top-Trainer
Referenzkunden
Teilnehmerfeedback
Angebotsanfrage
Offene Seminare
.NET-Akademie
.NET/C#-Basisseminar
WPF
WinUI
.NET MAUI
Blazor
ASP.NET WebAPI & gRPC
Entity Framework Core
Unit Testing / TDD
PowerShell
Infotage
Wissen
Übersicht
Fachbücher
Fachartikel
Konferenzvorträge
Konferenzen/Events
Spickzettel
Lexikon/Glossar
Programmcodebibliothek
Versionshistorie
Weblog
Downloads
Newsletter
Community-/Leserportal
Registrierung
.NET/C#/Visual Studio
.NET 10.0
.NET 9.0
.NET 8.0
ASP.NET (Core)/Blazor
PowerShell
Über uns
Kontakt
Selbstdarstellung
Kernkompetenzen
Dr. Holger Schwichtenberg
Top-Experten
Leitung & Kundenteam
Referenzkunden
Kundenaussagen
Referenzprojekte
Partner
Konditionen
Stellenangebote
Weitere Websites
Impressum
Datenschutzerklärung, Haftung, Urheberrecht, Barrierefreiheit
Suche
Themenkatalog
Tag Cloud
Volltextsuche
Site Map
FAQs
Erklärung des Begriffs: Objekt-Pipelining
Zur Stichwortliste unseres Lexikons
Was ist
Objekt-Pipelining
?
Objekt-Pipelining ist ein Konzept der Microsoft PowerShell zum Austausch von typisierten Objekten zwischen Befehlen (
Commandlet
s). Das objektorientierte Pipelining ist im Gegensatz zum in den Unix-Shell verwendeten zeichenkettenbasierten Pipelining nicht abhängig von der Position der Informationen in der
Pipeline
. Für eine
Pipeline
wird in der PowerShell – wie auch unter Unix üblich – der vertikale Strich (|) verwendet.
PowerShell
Pipeline
Processor reicht Objekt von Upstream- zu Downstream-Objekt weiter.
Beispiele
Get-Process | Where-Object { $_.name -eq "iexplore" } | Format-Table ProcessName, WorkingSet
get-childitem c:\daten -filter *.dll | where-object {$_.Length -gt 40000 | sort-object Lengt| format-list
Get-Alias | where { $_.definition -match "get-process" }
Weitere Informationen
Seine Mächtigkeit entfaltet die PowerShell erst durch das Pipelining, also durch die Weitergabe von Daten von einem
Commandlet
zum anderen.
Objektorientierung
ist die herausragende Eigenschaft der
Windows PowerShell
:
Commandlet
s können durch
Pipeline
s mit anderen
Commandlet
s verbunden werden. Anders als
Pipeline
s in Unix-Shell tauschen die einzelnen Befehle keine Zeichenketten, sondern typisierte
.NET
-Objekte aus.
Die
Liste
der laufenden Dienste erhält man mit dem Befehl
Get-Service | Where-Object {$_.status –eq "running"}
Die
Liste
der gestoppten Dienste liefert dementsprechend
Get-Service | Where-Object {$_.status –eq "stopped"}
Eine
Pipeline
kann beliebig lang sein. Der nächste Befehl exportiert die
Liste
der Namen der gestarteten Dienste in einer
CSV
-Datei:
Get-Service | Where-Object {$
.status -eq "running"} | select-object Name, DisplayName s | export-csv j:\wip
kolumne\dienste.csv
Get-Service legt
.NET
-Objekte des Typs System
System.ServiceProcess
.ServiceController in die
Pipeline
. Status Name und DisplayName sind
Attribut
e dieser
.NET
-Klasse. Where-Object filtert Objekte in der
Pipeline
. Select-Object beschneidet die einzelnen Objekte in der
Pipeline
, sodass nur noch die beiden Namen übrig bleiben. Sinnvoll zur Schonung der CPU-Belastung ist die obige Reihenfolge von Where-Object und Select-Object (stärkste Einschränkung zuerst). Aber auch die umgekehrte Reihenfolge ist möglich und würde zum gleichen Ergebnis führen.
get-process | format-list
bedeutet, dass das Ergebnis der get-process-Operation an format-list weitergegeben werden soll. Die Standardausgabeform von get-process ist eine Tabelle. Durch format-list werden die einzelnen
Attribut
e der aufzulistenden
Prozesse
untereinander statt in Spalten ausgegeben. Ein Beispiel für eine komplexere
Pipeline
ist:
get-children c:\daten -filter *.dll
| where-object "Length -gt 40000
| sort-object Length
| format-list
get-children ermittelt alle Dateien in c:\daten. Durch das zweite
Commandlet
(where-object) wird die Ergebnismenge auf diejenigen Objekte beschränkt, bei denen das
Attribut
Length größer ist als 40000. Durch das dritte
Commandlet
in der
Pipeline
wird die Ausgabe nach dem
Attribut
Length sortiert. Mit dem letzten
Commandlet
schließlich wird eine
Liste
ndarstellung erzwungen.
Im Gegensatz zu klassischen Shell-
Pipeline
s tauscht die PowerShell keine Zeichenketten zwischen den Befehlen aus, sondern
.NET
-Objekte, die durch
Reflection
analysiert werden. Genau genommen bezeichnet Microsoft das Verfahren als "Extended
Reflection
", weil die PowerShell erhebliche Hilfe beim Analysieren der Eingabeobjekte leistet. Für die Übergabe der
.NET
-Objekte an die
Commandlet
s sorgt der PowerShell
Pipeline
Processor. Die Basisklasse
Cmdlet
stellt den einzelnen
Commandlet
-Klassen eine Reihe von
Datenstruktur
en und
Methode
n zur Verfügung, die den einzelnen
Commandlet
s das Handling der Input- und Output-
Pipeline
vereinfacht. Die von Microsoft vordefinierten Befehle liefern sowohl Objekte aus der
.NET
-Klassenbibliothek als auch
WMI
-Objekte.
Die Reihenfolge der einzelnen Befehle in der
Pipeline
ist dabei nicht beliebig. Keineswegs kann man im obigen Befehl die Sortierung hinter die Formatierung setzen, weil nach dem Formatieren zwar noch ein Objekt existiert, dies aber ein unstrukturierter und untypisierter Ausgabestrom ist. where-object und sort-object könnte man vertauschen; aus Gründen des Ressourcenverbrauchs sollte man aber erst einschränken und dann die verringerte
Liste
sortieren. Die Anzahl der Befehle in einer einzigen
Pipeline
ist nicht begrenzt. Mehrere
Commandlet
s in einer
Pipeline
können parallel durch die PowerShell ausgeführt werden, da ein einzelnes
Commandlet
bereits Daten senden darf, auch wenn es noch nicht alle Daten des vorherigen Befehls empfangen hat. Ein
Commandlet
wird sofort aufgerufen, sobald das erste Objekt bereitsteht.
Tipp
Den Inhalt der
Pipeline
kann man übrigens mit dem
Commandlet
get-member analysieren.
Weitere Ressoucen auf dieser Website
PowerShell-Community-Website
PowerShell-Codebeispiele
Querverweise zu anderen Begriffen im Lexikon
System.ServiceProcess
Windows PowerShell (WPS)
Objektorientierung (OO)
Datenstruktur
Commandlet (Cmdlet)
Reflection
Prozesse
Pipeline
Attribut
Methode
Liste
.NET (DOTNET)
Commandlet (Cmdlet)
Comma Separated Value (CSV)
Windows Management Instrumentation (WMI)
Beratung & Support
Anfrage für Beratung/Consulting zu OBJEKT-PIPELINING
Gesamter Beratungsthemenkatalog
Technischer Support zum OBJEKT-PIPELINING
Schulungen
Konsolenanwendungen mit .NET
Windows PowerShell 5.1/PowerShell 7.0 für System- und Netzwerkadministratoren
Anfrage für eine individuelle Schulung zum Thema OBJEKT-PIPELINING
Gesamter Schulungsthemenkatalog
Fachbücher
Blazor 10.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 10.0, C# 14.0 und Visual Studio 2026
C# 14.0 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 10.0
.NET 10.0 Update: Die Neuerungen in .NET 10.0 gegenüber .NET 9.0
Blazor 9.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 9.0, C# 13.0 und Visual Studio 2022
C# 13.0 Crashkurs
Cross-Plattform-Apps mit .NET MAUI entwickeln
Moderne Datenzugriffslösungen mit Entity Framework Core 9.0
.NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
.NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
Concurrency with Modern C++: What every professional C++ programmer should know about concurrency
C++20: Get the Details
Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
C# 12.0 Crashkurs
App-Entwicklung für Mobile und Desktop: Software Engineering mit .NET MAUI und Comet für iOS, Android, Windows und macOS
Cross-Plattform-Apps mit .NET MAUI entwickeln
Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
C# 11.0 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
C++ Core Guidelines Explained: Best Practices for Modern C++
App Engineering: SwiftUI, Jetpack Compose, .NET MAUI und Flutter
Vue.js 3 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
C# 10.0 Crashkurs
Cross-Plattform-Apps mit Xamarin.Forms entwickeln
Developing Web Components with TypeScript: Native Web Development Using Thin Libraries
Alle unsere aktuellen Fachbücher
E-Book-Abo für ab 99 Euro im Jahr