Dies ist eine alte Version des Dokuments!
awk ist Zeilenorientiert - alle Anweisungen (außer Begin und End) auf die aktuell eingelesene Zeile angewendet. Anschließend wird die nächste Zeile eingelesen und das gleiche wiederholt.
Jede Zeile (Record) wird in Felder (Fields) zerlegt, auf die über Variablen $1 bis $x zugegriffen werden kann.
Die Zeichen anhand der das Ende eines Rekord (Zeile) erkannt wird kann frei definiert werden, gleiches gilt das Zeichen anhand dessen die einzelnen Fields (Felder) separiert werden - Default: New Line-Character bzw. Space.
Syntax:
BEGIN { Code; } /PATTERN/{ Code; } END{ Code; }
Es gibt mehrere Bedingungen bzw. Gestaltungsmöglichkeiten dieser.
Syntax:
/Regular Expression/{ some Code }
Beispiel:
/192.168.20.[0-9]/{ some Code }
Beispiel matcht wenn die IP mit 192.168.20 beginnt und auf 0-9 endet.
192.168.20.9“ heißt.
Sind komplexere Bedingungen bei denen gegen Feld-Variablen oder andere Variablen geprüft werden kann.
Mehrere Bedingungen können verknüpft werden.
Syntax:
Variable Vergleichsoperator Ausdruck{ Code } <code> \\ \\
Es gibt 3 Arten von Variablen.
Fields
Built-In
Einige Variablen:
Name | Beschreibung |
---|---|
FS | Field Separator - Definiert das Trennzeichen bzw. den Regular Expression zum Trennen der Fields/Felder. |
RS | Record Separator - Definiert das Trennzeichen bzw. den Regular Expression zum Trennen der Records/Zeilen |
OFS | |
ORS | Output Record Seperator - Definiert wie Records bei der Ausgabe getrennt werden. Per Default durch New Line (\n). Bei der Ausgabe ist ein Record ein print-Statement und alles was dies ausgibt. Gibt es mehrere Ausgaben durch print, startet jedes print-Statement einen neue Zeile/Record - auch wenn sie das Ergebnis der gleichen Eingabezeile/Eingaberecord sind. ps axu | awk 'BEGIN{ORS="; "}{print $2, $11; print "zweite ausgabe"}'
1 /sbin/init; zweite ausgabe; 2 [kthreadd]; zweite ausgabe;
|
* match-Funktionen ergeben auch true wenn nur ein Teilstring gematcht wird
Syntax:
BEGIN { Code; } /PATTERN/{ Code; } END{ Code; }