Aus Raspberry Pi Geek 04/2017

Shell-Skripte selbst schreiben (Teil 1) (Seite 5)

In der Praxis leiten Sie so komfortabel Daten in verschiedene Dateien oder Geräte um. Tabelle “File-Deskriptoren” zeigt die Regeln für die zusätzlichen Kanäle. Bei Kanälen zum Lesen und Schreiben gilt es, beide Schritte zum Aufheben vorzunehmen.

File-Deskriptoren

Anweisung

Aktion

exec Ziffer>Ziel

Ausgabekanal anlegen

exec Ziffer<Quelle

Eingabekanal anlegen

exec Ziffer<>Datei

Ein/Ausgabekanal anlegen

Befehl >&Nr

Ausgabe auf Kanal Nr

exec Ziffer>&-

Ausgabekanal aufheben

exec Ziffer<&-

Eingabekanal aufheben

Hier hängen Sie Ausgaben ebenfalls an bestehende Dateien an, indem Sie das Zeichen > doppelt verwenden. Nicht mehr benötigte Deskriptoren sollten Sie unbedingt wieder aufheben. Ein selbsterklärendes Anwendungsbeispiel finden Sie in Listing 13.

Listing 13

#! /bin/bash
# Testdateien erzeugen
echo -e "erste\nzweite\ndritte\n" > eingabe.txt
echo -e "eins\nzwei\ndrei\n" > puffer.txt
echo "Das ist lesbar"
# Anlegen Ausgabekanal 3:
exec 3>zieldatei2.txt
# Anlegen Eingabekanal 4:
exec 4<eingabe.txt
# Anlegen Ein-/Ausgabekanal 5:
exec 5<>puffer.txt
# Setzen Umleitung stdout und stderr
exec >zieldatei1.txt 2>fehlerlog
echo "Das kommt in die Datei"
# Ausgabe über Kanal 3
echo "Das kommt in die andere Datei" >&3
echo "Die einzelne Anweisung zur Umleitung ist nicht nötig!"
# Erzeugen einer Fehlermeldung
ls neuedatei.txt
# Auslesen aus Kanal 4 und schreiben auf Kanal 3:
read A <&4
echo $A >&3
# Benutzung der Datei puffer.txt
tail -1 <&5
echo "Neue Zeile" >&5
# Schließen zusätzlicher Kanäle:
exec 3>&-
exec 4<&-
exec 5<&-
exec 5>&-

Tests für die Shell

Das Paket coreutils enthält ein Werkzeug namens Test, um Entscheidungen auf der Basis von Tests zu treffen. Es wertet das Zutreffen bestimmter Bedingungen aus; als Kriterien kommen Vergleiche von Zahlen, Zeichenketten oder Eigenschaften von Objekten im Verzeichnisbaum des Rechners infrage.

Der Befehl kennt zwei unterschiedliche Formen der Syntax. In der Klammerform, die in der Praxis häufig vorkommt, steht die Anweisung innerhalb eckiger Klammern (if [ $? -eq 0 ]). Beachten Sie, dass zwischen der eckigen Klammer und dem Inhalt ein Leerzeichen stehen muss. In der ausgeschriebenen Form fallen die eckigen Klammern weg (if test $? -eq 0).

Der Befehl gibt einen Exit-Code aus. Die   steht dabei für “wahr”, die 1 für “falsch”. Es gibt die Möglichkeit, Ausdrücke zu negieren. Das signalisieren Sie durch ein mit Leerzeichen abgetrenntes, vorangestelltes Ausrufezeichen ([ ! -e Datei ]). Die Tabelle “Test-Varianten” liefert eine Übersicht über die Möglichkeiten des Tools.

Test-Varianten

Ausdruck

Erläuterung

Vergleichen von Zeichenketten

[ "$A" ]

wahr, wenn Variable $A nicht leer ist

[ -z "$A" ]

wahr, wenn Variable $A leer ist

[-n "$A" ]

wahr, wenn die Länge der Zeichenkette in $A nicht   beträgt

[ "$A" = "$B" ]

wahr, wenn der Inhalt beider Variablen gleich ist

[ "$A" != "$B" ]

wahr, wenn der Inhalt der beiden Variablen ungleich ist

Vergleichen von ganzen Zahlen

[ $A -eq $B ]

wahr, wenn die Werte gleich sind

[ $A -ne $B ]

wahr, wenn die Werte ungleich sind

[ $A -gt $B ]

wahr, wenn $A größer als $B ist

[ $A -ge $B ]

wahr, wenn $A größer oder gleich $B ist

[ $A -lt $B ]

wahr, wenn $A kleiner als $B ist

[ $A -le $B ]

wahr, wenn $A kleiner oder gleich $B ist

Eigenschaften von Objekten

[ -e Objekt ]

wahr, wenn Objekt existiert

[ -b Objekt ]

wahr, wenn Objekt ein Blockgerät ist

[ -c Objekt ]

wahr, wenn Objekt ein Zeichengerät ist

[ -d Objekt ]

wahr, wenn Objekt ein Verzeichnis ist

[ -f Objekt ]

wahr, wenn Objekt eine Datei ist

[ -g Objekt ]

wahr, wenn für Objekt die Gruppen-ID-Bit gesetzt ist

[ -k Objekt ]

wahr, wenn für Objekt das Sticky-Bit gesetzt ist

[ -u Objekt ]

wahr, wenn für Objekt das UID-Bit gesetzt ist

[ -s Objekt ]

wahr, wenn die Größe von Objekt ungleich 0 ist

[ -p Objekt ]

wahr, wenn Objekt ein FIFO ist

[ -S Objekt ]

wahr, wenn Objekt ein Socket ist

[ -L Objekt ]

wahr, wenn Objekt ein symbolischer Link ist

[ -r Objekt ]

wahr, wenn das Leserecht für Objekt gesetzt ist

[ -w Objekt ]

wahr, wenn das Schreibrecht für Objekt gesetzt ist

[ -x Objekt ]

wahr, wenn das Recht zum Ausführen von Objekt gesetzt ist

[ -O Objekt ]

wahr, wenn der Abfrageprozess den selben Eigentümer aufweist

[ -G Objekt ]

wahr, wenn der Gruppeneintrag von Prozess und Datei übereinstimmen

[ Objekt1 -nt Objekt2 ]

wahr, wenn Objekt1 neuer als Objekt2 ist

[ Objekt1 -ot Objekt2 ]

wahr, wenn Objekt1 älter als Objekt2 ist

[ Objekt1 -ef Objekt2 ]

wahr, wenn Objekt1 und Objekt2 sich auf dasselbe Objekt beziehen

Vergleich von Testausdrücken

[ Ausdruck1 -a Ausdruck2 ]

wahr, wenn Ausdruck1 und Ausdruck2 wahr sind

[ Ausdruck1 -o Ausdruck2 ]

wahr, wenn Ausdruck1 oder Ausdruck2 wahr ist

Fazit

Wer die Möglichkeiten einer Shell wie der Bash voll ausreizt, kommt meist im ersten Anlauf ohne eine weitere Programmiersprache aus. Einfache Abläufe und Abfragen (selbst mit Benutzerinteraktion) sowie komplexe Operationen auf Dateien gelingen ohne zusätzliche Tools. Beim Arbeiten mit den Skripten erleben Sie außerdem die grundlegenden Funktionsprinzipien eines Linux-Systems in Aktion. Das vermittelt wertvolle Aufschlüsse, die Ihnen dann an anderen Stellen weiterhelfen. 

DIESEN ARTIKEL ALS PDF KAUFEN
EXPRESS-KAUF ALS PDFUmfang: 8 HeftseitenPreis €0,99
(inkl. 19% MwSt.)
RASPBERRY PI GEEK KAUFEN
EINZELNE AUSGABE Print-Ausgaben Digitale Ausgaben
ABONNEMENTS Print-Abos Digitales Abo
TABLET & SMARTPHONE APPS Raspberry Pi Geek bei Google Play Readly Logo
Nach oben