Hauptindex | Abschnitt 1 | English | 日本語 | Optionen |
egrep unterscheidet sich nur in der Syntax einiger Ausdrücke vom grep Kommando. Als Ausdruck akzeptiert egrep reguläre Ausdrücke mit den folgenden Steuerzeichen:
c | ein einzelner Buchstabe paßt auf sich selbst |
. | ein Punkt paßt auf jeden Buchstaben außer auf das Zeilenende |
? | das dem Fragezeichen vorangehende Zeichen bzw. Muster kann null oder einmal vorkommen |
* | das dem Asterisk * vorangehende Zeichen oder Muster kann 0 mal oder öfter vorkommen |
+ | das dem Pluszeichen + vorangehende Zeichen bzw. Muster kann 1 mal oder öfter vorkommen |
| | die durch den Operator | verbundenden Argumente werden oder verknüpft |
^ | (Caret) paßt auf den Zeilenanfang |
$ | paßt auf das Zeilenende |
\lt; | paßt auf den Wortanfang |
\gt; | paßt auf das Wortende |
[Buchstaben] | |
paßt auf alle Buchstaben; dabei können einzelne Buchstaben, aber auch Bereiche in der Form von-bis angegeben werden; wenn der erste Buchstabe nach [ein^ist, paßt der Ausdruck auf alle Buchstaben außer den aufgeführten | |
() | die Klammern fassen Ausdrücke und Zeichenketten zusammen; außerdem wird der auf den in Klammern eingeschlossene Teil des Musters passende Text markiert und mit einem folgenden \N Ausdruck referenziert (Tag) |
\N | referenziert die auf das in den N-tens runden Klammern eingeschlossene Muster passende Zeichenkette. |
\ | jedes der Sonderzeichen kann, durch ein \(Backslash) eingeleitet, sich selbst suchen |
\ | paßt auf kein Zeichen, sondern auf den Anfang oder das Ende eines Wortes |
\ | steht für den Raum innerhalb eines Wortes |
\ | paßt auf alle alphanumerischen Zeichen [A-Za-z0-9] |
\ | paßt auf alle nicht alphanumerischen Zeichen [^A-Za-z0-9] |
(, ), ?, *, + und |
Die anderen Operatoren sind mit den anderen Buchstaben gleichrangig.
-A Anzahl | |
gibt Anzahl Zeilen Kontext nach jeder gefundenden Zeile aus | |
-B Anzahl | |
gibt Anzahl Zeilen Kontext vor jeder gefundenden Zeile aus | |
-C | gibt 2 Zeilen Kontext vor und nach jeder gefundenden Zeile aus |
-Anzahl | |
gibt Anzahl Zeilen Kontext vor und nach jeder gefundenden Zeile aus | |
-V | gibt die Versionsnummer auf die Standardfehlerausgabe |
-b | gibt die Position jeder gefundenen Stelle mit aus |
-c | gibt nur die Gesamtzahl der gefundenen Stellen aus |
-e Ausdruck | |
sucht nach Ausdruck | |
-f Datei | |
Datei enthält die Ausdrücke, nach denen gesucht werden soll | |
-h | unterdrückt die Dateinamen vor jeder Fundstelle |
-i | ignoriert Groß- und Kleinschreibung |
-l | gibt nur die Dateinamen mit Fundstellen aus |
-n | gibt die Zeilennummer zu jeder Fundstelle aus |
-s | (silent) keine Ausgabe außer Fehlermeldungen |
-v | gibt nur Zeilen aus, die den Ausdruck nicht enthalten |
-w | gibt nur Zeilen aus, in denen der Ausdruck als komplettes Wort vorkommt |
-x | gibt nur Zeilen aus, die den Ausdruck als ganze Zeile enthalten |
egrep 'sys_.*[^;]$' *.c
liefert, im Verzeichnis /usr/src/linux/kernel ausgeführt, die erste Näherung einer Liste aller Systemaufrufe von Linux. Es werden alle C-Sourcen nach Zeilen durchsucht, die die für die Funktionsnamen der Systemaufrufe typischen Buchstaben sys_ enthalten, und die gleichzeitig nicht mit einem Semikolon enden.
Die beiden in diesem Beispiel verwendeten Asterisk Wildcards * haben grundlegend unterschiedliche Funktion: das erste, in Hochkomma eingeschlossene, wird dem egrep Kommando übergeben und mit dem Ausdruck ausgewertet. Das zweite wird von der Shell interpretiert, die daraus eine Liste aller Dateinamen mit der Endung .c im aktuellen Verzeichnis erzeugt.
Mit dem Kommando
egrep '(.......).*' Handbuch.tex
kann in der Datei Handbuch.tex nach Zeilen gesucht werden, in denen eine Zeichenkette aus sieben Zeichen doppelt vorkommt.
1. Juli 1993 | EGREP (1) | LunetIX Linuxhandbuch |
Hauptindex | Abschnitt 1 | English | 日本語 | Optionen |
Bitte richten Sie Ihre Kommentare zu diesem Handbuch Seite Service, Ben Bullock. Privacy policy.
“ | Did you know that 7/5 people don't know how to use fractions? | ” |