260 likes | 377 Views
Eine Welt jenseits von Fenstern und Mausklicks. und sogar modern…. Es war einmal…. ENIAC, Quelle: Wikipedia. Die ersten Computer hatten nicht mal Bildschirme, geschweige denn Grafik. Immerhin…. Nach Druckern (eher gesteuerten Schreibmaschinen) kamen die Bildschirme. Maus? Nix Maus!.
E N D
Eine Welt jenseits von Fenstern und Mausklicks und sogar modern…
Es war einmal… ENIAC, Quelle: Wikipedia Die ersten Computer hatten nicht mal Bildschirme, geschweige denn Grafik
Immerhin… Nach Druckern (eher gesteuerten Schreibmaschinen) kamen die Bildschirme
Maus? Nix Maus! Programme zeigten „nur“ Text an Auch die Steuerung des Betriebssystems geschah ausschließlich per Tastatur
Wie war das „damals“? • Gewohnt! • Die Maus gab‘s einfach noch nicht. • Einfach! • Es gab nicht viel, was man tun konnte. • Also auch wenig zu lernen. • Kompliziert! • Mehr oder weniger systematisch – je nach Hersteller und System • Die Kommandozeile konnte mehr und mehr…
Programme gab‘s damals auch Anwendungsprogramme, auch Spiele:
Die Kommandozeile heute • Scripts sind enorm wichtig für die effiziente Verwaltung großer Systeme • Nützlich und interessant auch für kleine! • Es gibt viele verschiedene „Shells“ • Scriptsysteme je nach Betriebssysteme
Was gucken wir heute an? • Was? • Die Microsoft Windows PowerShell 2.0 • Warum? • Sehr systematisch - leicht zu erlernen • Sehr modern und extrem mächtig • (Das wurde aber auch Zeit, Microsoft!) • Und die anderen? • Kann man auch erlernen, wenn man möchte • Erst recht, wenn man mal eine gesehen hat
Also los! Text alleine oder Text in einem Fenster – letztlich egal
Befehle • Befehle nennen sich „CommandLets“ • Grundsätzlich einheitlich: Verb-Objekt • Get-… liest irgendetwas aus • Da geht also nichts kaputt
Denn sie wissen, was sie tun • Befehle können Parameter bekommen • Damit kann man Details steuern • Get-ChildItem *.txt • Damit klar ist, welche Dinge wir sehen wollen • Get-Content c:\boot.ini • Damit klar ist, welche Datei wir ausgeben wollen • Befehle haben Namen • Get-ChildItem -Path *.txt • Get-Content -Path *.txt • Get-ChildItem -?
Hülfäää! • Hilfe gibt’s mit -? als Parameter • Out-Printer -? • Get-Help gibt Hilfe • Get-Help Format-Table -Full • Get-Memberliefert Informationen über Objekte • Die wichtigsten Befehle sind also • Get-Help • Get-Command • Get-Member (später)
Pssst! • Für Faule und Gewohnheitstiere: Aliase! • Get-ChildItem = gci = dir = ls • Get-Help = help • Format-Table = ft • Format-List = fl • Out-Host -Paging = more • Woher weiß man das? • Get-Alias • Tab-Completion! • get-c tab Get-ChildItem • format tab tab tab Format-List
Format-Table? Format-List? • Ausprobieren! • Get-ChildItem | Format-Table Name, Length • Get-ChildItem | Format-List Name, Length • Get-ChildItem | Format-Wide • Get-ChildItem | Out-GridView • Bloß – warum funktioniert das?
PowerShell ist anders Alle anderen Shells liefern einfach Text
Gag #1: Objekte • PowerShell liefert nicht Text, sondern „Objekte“ • Datenpakete mit Aufklebern: „Eigenschaften“ • „Ich (eine Datei) habe eine Eigenschaft Name, und das ist ein Stück Text.“ • „Ich (eine Datei) habe eine Eigenschaft Length, und das ist eine Zahl.“ • Eingebauter Werkzeugkasten: „Methoden“ • „Ich (ein Computer) kenne eine Methode Reboot()“ • Für Fortgeschrittene • Get-Member listet die Eigenschaften und Methoden der Objekte auf
Gag #2: Pfeifen sind super • Der senkrechte Strich zwischen zwei Befehlen leitet die Objekte von einem zum nächsten weiter • Befehl1 | Befehl2 | Befehl3 | Befehl4 • Jeder Befehl kann irgendwas mit den Daten machen, und irgendwas ausgeben • Das kommt dann als Eingabe in den nächsten Befehl • Wenn beim letzten Befehl etwas herauskommt, wird es angezeigt • Das können viele andere Shells auch • … aber eben nur mit Text, nicht mit sich selbst beschreibenden Objekten
Befehle für die Pipe • Sort-Objectsortiert Objekte nach ihren Eigenschaften • Select-Objectlässt nur bestimmte Eigenschaften durch • (kann auch neue Eigenschaften bilden) • Where-Objectfiltert Objekte nach irgendwelchen Bedingungen • lässt nur die erwünschten durch • ForEach-Objecttut irgendetwas mit jedem ankommenden Objekt
Jetzt mal was Längeres • Alles in eine Zeile tippen: • Get-ChildItem -Filter *.txt -Recurse | Where-Object {$_.Length -lt 10000} | Sort-Object Length | Select-Object FullName | Out-Host -Paging • Get-ChildItem -Filter *.txt –Recurse | Where-Object {$_.Length -lt 10000} | Sort-Object Length | Select-Object FullName | Out-GridView
Ganz schön lang? • Zwei Mal dasselbe verarbeiten – geht das nicht einfacher? • Doch (natürlich): Mit Variablen • Variablen speichern Objekte • Fangen mit $ an und haben einen Namen • $daten = Get-ChildItem -Filter *.txt –Recurse | Where-Object {$_.Length -lt 10000} | Sort-Object Length • $daten | Export-Csv Datei.csv • $daten | Out-GridView • $daten | Select-Object -First 5 | Out-Printer • $_in Where-Object, ForEach-Objectusw. enthält das jeweilige Objekt in der Pipe
Immer dasselbe… • Es werden oft dieselben Dinge benötigt • Dafür gibt es Scriptdateien • In der PowerShell enden die auf .ps1 • Man muss sie aber erst einschalten • Aus Sicherheitsgründen • Set-ExecutionPolicy RemoteSigned • Bewirkt, dass Scripts vom lokalen Computer auch ohne digitale Signatur ausgeführt werden • Das kann nur ein Administrator einstellen
Ein Beispiel • Von was für Typen von Dateien habe ich wie viele? • Get-ChildItem -Recurse | Group-Object Extension | Sort-Object Count -Descending | Select-Object Name, Count -First 10 • Z. B. als Get-ExtensionStatistic.ps1 speichern • Aufrufbar nur mit ausdrücklicher Verzeichnisangabe • .\Get-ExtensionStatistics.ps1(aus dem aktuellen Verzeichnis)
Wer mehr will • Nützliche CommandLets: • Copy-Itemkopiert Dateien (und anderes) • Set-Locationwechselt das aktuelle Verzeichnis • Remove-Itemlöscht • Vorsicht! Datenverlust! • Erstmal mit -WhatIfoder -Confirmausprobieren! • Group-Objectstellt Objekte in Gruppen mit gleichen Eigenschaftswerten zusammen • Measure-Objectberechnet: zählt, summiert • Get-ChildItem | Measure-Object Length -Sum
Wer alles will Siehe auch: http://www.ct-systeme.com/sf/tools/publisher/Seiten/Kommandozeile.aspx PowerShell ist .NET auf der Kommandozeile .NET kann dynamisch DLLs nachladen Also kann PowerShell das auch:
Und wir sind erst am Anfang • Wir haben gerade mal ganz leicht an der Oberfläche gekratzt! • PowerShell kann noch viel mehr: • Computer im Netzwerk finden, auf denen nur noch wenig Platz frei ist • Zugriffsrechte einstellen • Datenbanken abfragen • E-Mail senden • Dateien von einem Webserver herunterladen • Typ der Grafikkarte feststellen • Software installieren • Und… • Königreich Euphoria spielen • http://www.ct-systeme.com/Lists/Downloads/DispForm.aspx?ID=46