LPIC101/103.7 Regulären Ausdrücke
Wichtung : 3
Begriffsklärung
Was sind reguläre Ausdrücke?
- Reguläre Ausdrücke erleichtern das durchsuchen von Texten
- Sie beschreiben anhand von Wildcards, Suchwörtern und Positionsangaben und ermöglichen so eine differenziertere Suche
- Wildcards werden auch Jokerzeichen genannt und sind Platzhalter für ein oder mehrere Zeichen
- Reguläre Ausdrücke werden in englisch Regular Expressions genannt
- Reguläre Ausdrücke werden meist mit RegEx oder RegExp abgekürzt
Wo kann man reguläre Ausdrücke verwenden?
- Mit dem Filter "grep" in der Shell
- Mit dem Vi-Editor in der Shell
- Im Kate Editor (Option {} aktivieren im Suchen Fenster)
- In vielen weiteren Programmen
Gültige Metazeichen
Metazeichen beschreiben die Position einer Suchanfrage. Gültige Metazeichen sind :
^
Textanker für Zeilenanfang$
Textanker für Zeilenende\<
markiert einen Wortanfang\>
markiert ein Wortende\
schützt ein Zeichen vor der Interpretation (z.B. /$ sucht nach Dollarzeichen und nimmt diesen seine Spezialbedeutung)[]
sucht nach einem Zeichen oder einer Zeichenfolge innerhalb des eckig geklammerten Bereichs (z.B. [a-g] )[^Zeichen]
Schließt das Zeichen nach dem Circonflex aus der Suche aus
Wildcards (Joker)
*
bezeichnet keine oder beliebig viele Wiederholungen des vorangegangenen Zeichens?
bezeichnet keine oder eine Wiederholung des vorangegangenen Zeichens+
bezeichnet, dass das voranstehende Zeichen mindestens einmal vorkommt.
wird als Platzhalter für ein beliebiges Zeichen verwendet
Verwendung von grep mit regulären Ausdrücken
- Der Filter grep bedeutet "Global search for Regular Expressions and Print out" (Sinngemäß: Globale Suche durch Reguläre Ausdrücke mit Ausgabe).
Hinweise für die Verwendung von grep:
-v
ist bei grep nicht verbose (Gesprächigkeit), sondern invertiert die Ausgabe (z.B. grep -v "Testwort" zeigt alle Zeilen ohne Testwort)-E
aktiviert erweiterte reguläre Ausdrücke (entspricht dem Befehl egrep)-i
ignoriert Groß- & Kleinschreibung
Beispiele für Verwendung von grep mit RegEx:
archangel:~ # grep [Ww]ill[iy] Adressliste
– sucht in der Datei Adressliste nach Willi,willi,Willy und willy. (grep -i Will[iy] liefert das gleiche Ergebnis, ignoriert jedoch auch die Groß- & Kleinschreibung von den anderen Buchstaben)archangel:~ # grep W.lly Adressliste
– der Punkt ersetzt ein beliebiges Zeichen, somit würden Willy, Wally usw. gefunden werden, sofern diese existieren.archangel:~ # grep -v ^[#] /etc/config.conf
oder Alternativarchangel:~ # grep ^[^#] /etc/config.conf
– findet alle Zeilenanfänge, welche nicht mit einer Raute beginnenarchangel:~ # grep ^[^#] /etc/config.conf | grep -v ^$
– Sucht alle Zeilenanfänge ohne Raute und mit Zeichen am Anfang (siebt Leerzeilen aus, Leerzeile ist Zeilenanfang ^ gefolgt von Zeilenende $)archangel:~ # grep 'Wort[1-9]*\>' Suchdatei
– Sucht alle Wörter, welche mit "Wort" anfangen und anschließend beliebig viele Zahlen bis zum Wortende beinhalten.archangel:~ # grep 'Wort[1-9]\?\>' Suchdatei
– Sucht alle Wörter, welche mit "Wort" anfangen und anschließend eine beliebige einstellige Zahl bis zum Wortende beinhalten.archangel:~ # grep -w '1\{3,5\}' Suchdatei
– Mit dem folgenden Kommando werden alle Zeilen einer Datei angezeigt, die drei, vier oder fünf aufeinander folgende Einsen enthalten.
Kontrollfragen
Wonach sucht RegEx ^[^#]
Antwort : Nach einem Zeilenanfang ohne Raute
Sie geben im Kate Editor unter Suchen ohne RegExp "a*" ein. Was erhalten Sie als Antwort? Antwort : Sie suchen nach dem String "a*".
Sie geben in der Kate-Suche mit RegEx a* ein, was erhalten Sie als Antwort? Sie erhalten alle Wörter, welche mit einem a beginnen und eine bis beliebig viele Wiederholungen dieses Zeichens aufweisen.
Sie geben in der Shell den Eefehl ls a* ein, was erhalten Sie als Antwort? Sie erhalten alle Dateien und Verzeichnisse, welche mit a beginnen und deren Folgezeichen belibieg sein können.
Sie geben in der Shell den Eefehl ls a??? ein, was erhalten Sie als Antwort? Sie erhalten alle Dateien und Verzeichnisse, deren Name mit a beginnt und anschließend genau drei beliebige Folgezeichen beinhaltet.
Wie können Sie sich alle Einträge vom 10ten Dezember im Systemlog ansehen? Antwort : archangel:~ # grep '^Dec 10' /var/log/syslog
Wonach sucht das folgende RegEx Kommando : archangel:~ # grep –w '[0-9]\{3\}' Suchdatei ? Es sucht nach Zeilen, die drei aufeinander folgende Ziffern beinhalten.