Verwendung des Befehls Grep and Tree Linux

Eines der vielseitigsten Betriebssysteme, das über das Terminal verwaltet werden kann, ist zweifellos Linux in allen verfügbaren Distributionen, und dies dank der Integration zahlreicher Befehle, die in Ihrer Konsole verfügbar sind . Es spielt keine Rolle, ob wir ein Terminal-basiertes System (z. B. Serverversionen) oder eine GUI-basierte Umgebung (z. B. Desktop-Versionen) verwenden. In allen Fällen sind das Terminal und seine Befehle stets eine zuverlässige Quelle für Verwaltung und Unterstützung.

Zu unseren täglichen Aktivitäten gehört das Erstellen und Bearbeiten von Ordnern und Dateien, die je nach Rolle zahlreich sein können. Dies ist zu einem bestimmten Zeitpunkt normal, da die Suche nach Elementen auf die eine oder andere Weise nicht nur durch die Anzahl der Dateien, sondern auch durch den Speicherort, an dem sie gehostet werden, beeinträchtigt wird .

Um diese Art von Aktivitäten einfacher verwalten zu können, haben wir zwei wichtige Befehle für das Suchen und Anzeigen von Objekten in Linux, die Grep- und Tree-Befehle. TechnoWikis wird detailliert erklären, wie es verwendet wird und wie es in der Distribution , die wir unter Linux verwenden, ganzheitlich angewendet wird.

1. Was ist der GREP-Befehl?

Was ist der Grep-Befehl?
Grep ist ein Befehl, der für die Ausführung von Textsuchaufgaben entwickelt wurde. Grep ist dafür verantwortlich, in der Datei die Zeilen anzuzeigen, in denen eine Übereinstimmung entweder mit den Wörtern oder der Zeichenfolge festgestellt wird, die wir während der Ausführung zuweisen. Sein Name leitet sich vom UNIX-Editor g / re / p ab. Während der Ausführung von Grep ist es möglich, einen Dateinamen anzugeben oder die Standardeingabe beizubehalten. Daher ist Grep für die Generierung der übereinstimmenden Zeilen verantwortlich.

Grep-Variablen
Es gibt drei (3) Variablen, die während des Grep-Prozesses verwaltet werden:

  • -G, –basic-regexp: Dies ist für die Interpretation des Musters als regulärer Grundausdruck verantwortlich. Dies ist der Standardwert.
  • -E, –extended-regexp: Diese Option gilt für das Muster als erweiterter regulärer Ausdruck.
  • -F, –fixed-strings: Mit dieser Option wird das Muster als Liste fester Zeichenketten interpretiert, die durch Zeilenumbrüche getrennt sind und in denen nach Übereinstimmungen gesucht wird.

Schritt 1

Die allgemeine Syntax, die mehrere Parameter enthalten kann, lautet wie folgt:

 grep [-AB] num] [-CEFGVbchiLlnqsvwxyUu] [[-e] pattern | -f Datei] [--extended-regexp] [--fixed-strings] [--basic-regexp] [--regexp = PATTERN] [--file = FILE] [--ignore-case] [--word -regexp] [--line-regexp] [--line-regexp] [--no-messages] [--invert-match] [--version] [--help] [--byte-offset] [- -Zeilennummer] [--mit-Dateiname] [--kein-Dateiname] [--ruhig] [--leise] [--Dateien-ohne-Übereinstimmung] [--Dateien-mit-Matcces] [- count] [--before- context = NUM] [--after-context = NUM] [--context] [--binary] [--unix-byte-offsets] files ... 
Schritt 2

Wir werden einige Beispiele für die Verwendung von Grep sehen, bevor wir dessen Parameter kennen. Wenn wir das Verzeichnis / etc / passwd nach allem durchsuchen möchten, was sich auf einen bestimmten Benutzer bezieht, können wir Folgendes ausführen:

 grep "user" / etc / passwd 
Schritt 3

Das Ergebnis wird folgendes sein:

1-Was-ist-der-Befehl-GREP.png

Schritt 4

Es wird auch möglich sein, den Grep-Befehl zu zwingen, Groß- und Kleinbuchstaben zu ignorieren, d. H. Den Lösungsmittel-, TechnoWikis- oder SOLVETIC-Abgleich zusammen mit allen Kombinationen mit dem -i-Parameter zuzulassen:

 grep -i "solvetic" / etc / passwd 

2-Was-ist-der-Befehl-GREP.png

Schritt 5

Diese Option kann auch mit dem Befehl cat wie folgt ausgeführt werden:

 Katze / etc / passwd | grep -i "solvetic" 

2. Wie man den Grep-Befehl unter Linux rekursiv verwendet

Schritt 1

Grep gibt uns die Möglichkeit, eine rekursive Suche durchzuführen, das heißt, diese Suche liest alle Dateien in jedem Verzeichnis für eine bestimmte Kette, zum Beispiel die IP-Adresse des Teams, wir können eine der folgenden Optionen ausführen:

 grep -r "192.168.0.25" / etc / o grep -R "192.168.0.25" / etc / 

3-Was-ist-der-Befehl-GREP.png

Hinweis
Dort können wir die aktuelle IP-Adresse des verwendeten Gerätes eintragen.

Schritt 2

Dasselbe können wir auch mit der IP 192.168.1.5 ausführen, die das System für Standardausgaben verwendet:

See also  Ist es sicher, sofort ins Büro zurückzukehren?

4-Was-ist-der-Befehl-GREP.png

Schritt 3

Wir können feststellen, dass bei beiden IP-Adressen eine separate Zeile mit dem Namen der Datei, in der sie erkannt wurde, vorangestellt wird. Wenn wir die Einbeziehung dieses Werts ausschließen möchten, ist es möglich, ihn mit der Option -h wie folgt zu unterdrücken:

 grep -h -R "192.168.1.5" / etc / oder grep -hR "192.168.1.5" / etc / 

5-Was-ist-der-Befehl-GREP.png

Hinweis
Dieser Befehl muss vor dem Befehl als root oder sudo ausgeführt werden.

3. Verwenden des Grep-Befehls zum Ausführen von Wortsuchen unter Linux

Schritt 1

Grep ist nützlich, um nach Begriffen in einer bestimmten Datei zu suchen. Das Ergebnis hebt daher jede Zeile hervor, in der der Suchbegriff gefunden wurde, sowie die Wörter (nicht hervorgehoben), die zum Suchbegriff gehören. Die zu verwendende Syntax lautet wie folgt . In diesem Fall wurden 3 Übereinstimmungen in der TechnoWikis1-Datei gefunden.

 grep -w "word" Datei 

6-How-to-Use-the-Befehl-Grep-to-Execute-Wortsuche-in-Linu.png

Schritt 2

Wenn Sie in einer Datei nach zwei Begriffen suchen möchten, müssen Sie die folgende Syntax mit dem Befehl egrep ausführen. Wie wir sehen, werden die gesuchten Wörter im Ergebnis hervorgehoben.

 egrep -w 'term1 | term2' Datei 

7-Verwendung-des-Befehls-Grep-zum-Ausführen-von-Wortsuchen-unter-Linux.png

4. Verwendung des Grep-Befehls zum Zählen von Wörtern unter Linux

Schritt 1

Eine weitere praktische Option von Grep ist die Möglichkeit zu wissen, wie oft ein Wort in einer bestimmten Datei wiederholt wird. Dies wird durch den Parameter -c wie folgt erreicht:

 grep -c 'word' Datei 

8-How-to-Use-the-Befehl-Grep-to-Count-Wörter-in-Linux.png

Schritt 2

Alternativ können wir den Parameter -n verwenden, um jeder Ausgabezeile die Nummer der Zeile voranzustellen, in der sie in der ausgewählten Datei eingegeben wurde:

 grep -n 'word' Datei 

9-How-to-Use-the-Befehl-Grep-to-Count-Wörter-in-Linux.png

5. So erzwingen Sie die invertierte Grep-Suche

Bei der umgekehrten Suche bedeutet dies, dass der Befehl Grep nur Ergebnisse aus den Zeilen anzeigt, die das definierte Wort nicht enthalten. Dies wird mit dem Parameter -v wie folgt erreicht:

 grep -v Datei "Ich beende" 

10-How-to-Force-the-Inverted-Search-Grep.png

6. Verwenden von UNIX / Linux-Pipes neben dem Grep-Befehl

Schritt 1

Der Grep-Befehl in Linux kann beispielsweise mit UNIX-Shell-Pipes kombiniert werden. Wenn wir den Namen der Festplattengeräte auflisten möchten, führen wir die folgende Zeile aus:

 dmesg | egrep '(s | h) d [az]' 

11-How-to-Use-UNIX - Linux-Pipes-neben-Befehl-Grep.png

Schritt 2

Dort werden die Ergebnisse mit allen zugehörigen Informationen angezeigt. Um das CPU-Modell bereitzustellen, führen wir Folgendes aus:

 cat / proc / cpuinfo | grep -i 'Model' 

12-How-to-Use-UNIX - Linux-Pipes-neben-Befehl-Grep.png

Schritt 3

Für dasselbe Ergebnis können wir auch Folgendes ausführen:

 grep -i 'Model' / proc / cpuinfo 
Schritt 4

Eine der speziellsten Anwendungen des Befehls Grep oder egrep ist die Möglichkeit, die Ausgabe von herkömmlichen Befehlen wie yum, dpkg, apt oder apt-get zu filtern. Zum Beispiel können wir die folgende Zeile ausführen, um mit dpkg nach Linux-Images zu suchen:

 dpkg - liste | grep Linux-Image 

13 - How-to-Use-UNIX - Linux-Pipes-neben-Befehl-Grep.png

Schritt 5

Es wird möglich sein, die Suche mit apt auszuführen:

 passende suche maria | egrep 'server | client' 

14 - How-to-Use-UNIX - Linux-Pipes-neben-Befehl-Grep.png

7. Wie man nur die Namen der Dateien auflistet, die mit Grep übereinstimmen

Zu diesem Zweck können wir die Option -l verwenden, um den Namen der Datei aufzulisten, in der der Inhalt folgendermaßen hervorgehoben wird:

 grep -l 'end' * .c 
Grep-Befehlsparameter
Als nächstes werden wir die verschiedenen Variablen sehen, die Grep für die Verwaltung unter Linux anbietet:

  • -núm: Mit dieser Option werden die Konkordanzlinien neben den Nummern der vorherigen und nachfolgenden Linien angezeigt.
  • -A num, –after-context = NUM: Zeigt die Anzahl der Kontextzeilen an, nachdem sie mit den angegebenen übereinstimmen.
  • -B num, –before-context = NUM: Bei Verwendung dieser Option werden die Kontextzeilen vor denjenigen angezeigt, die der Suche entsprechen.
  • -V, –version: Zeigt die Versionsnummer von grep an.
  • -b, –byte-offset: Dieser Parameter zeigt den Offset in Bytes vom Anfang der Eingabedatei vor jeder Ausgabezeile an.
  • -c, –count: Zählt die Anzahl der Zeilen, die dem angegebenen Begriff entsprechen.
  • -h, –no-filename: Löscht den Ausdruck der Dateinamen im Ergebnis.
  • i, –ignore-case: Es wird nicht berücksichtigt, ob die Buchstaben groß oder klein geschrieben sind.
  • -L, –files-without-match: Diese Option zeigt den Namen jeder Eingabedatei an, in der keine Übereinstimmung gefunden wurde.
  • -l, –files-with-matches: Zeigt den Namen jeder Eingabedatei an, die ein Ergebnis erzeugen kann.
  • -n, –Zeilennummer: Ordnen Sie jeder Ausgabezeile die entsprechende Zeilennummer in der Suchdatei zu.
  • -q, –quiet: Aktiviert den Silent-Modus, der die normale Ausgabe unterdrückt und die Suche mit der ersten Übereinstimmung endet.
  • -s, –silent: Löscht die Fehlermeldungen.
  • -v, –invert-match: Diese Option kehrt die Bedeutung der Suche um, dh es werden die Ergebnisse angezeigt, die nicht mit dem Suchbegriff übereinstimmen.
  • w, –word-regexp: Dieser Parameter wählt nur die Zeilen aus, die Konkordanzen enthalten, die vollständige Wörter bilden.
  • -x, –line-regexp: Mit dieser Option werden nur die Konkordanzen ausgewählt, die aus der gesamten Zeile bestehen.
See also  So löschen Sie freien Speicherplatz in Windows 10, 8, 7

8. Verwenden und Installieren von Tree unter Linux

Wie der Name schon sagt, wurde der Befehl Tree entwickelt, um die Verzeichnisse des Systems in Form eines Baums anzuzeigen und die Verwaltung zu vereinfachen.

Der Befehl Tree verwendet einen rekursiven Befehl für Verzeichnislisten, der nur dann zu einem mit einer Reihe von Farben gestalteten Baumformat führt, wenn die Umgebungsvariable LS_COLORS gesetzt und die Ausgabe auf tty gesetzt ist, wenn keine Argumente zugewiesen sind. Dieser Befehl listet die Dateien im aktuellen Verzeichnis auf.

Schritt 1

Die allgemeine Syntax lautet wie folgt:

 tree [-acdfghilnpqrstuvxACDFQNSUX] [-L level [-R]] [-H baseHREF] [-T title] [-o filename] [--nolinks] [-P pattern] [-I pattern] [--inodes] [ --device] [--noreport] [--dirsfirst] [--version] [--help] [--filelimit #] [--si] [--prune] [--du] [--timefmt format ] [--matchdirs] [-] [Verzeichnis ...] 
Schritt 2

Der erste Schritt besteht darin, den Tree-Befehl durch Ausführen des folgenden Befehls zu installieren:

 sudo apt install tree 

15-How-to-Liste-nur-die-Namen-der-Dateien-Matching-mit-Grep.png

Schritt 3

Nach der Installation führen wir direkt den Befehl “tree” aus, um das aktuelle Verzeichnis im Baumformat aufzulisten:

16-How-to-Liste-nur-die-Namen-der-Dateien-Matching-mit-Grep.png

9. Arbeiten mit Dateien mit dem Tree-Befehl unter Linux

Mit Tree versteckte Dateien anzeigen
Standardmäßig zeigt der Tree-Befehl die versteckten Dateien aus Sicherheitsgründen nicht an. Wenn Sie sie im Ergebnis visualisieren möchten, können Sie zu diesem Zweck den -a-Parameter hinzufügen:

 Baum -a 

17-How-to-work-with-files-using-the-command-Tree-on-Linux.png

Nur Verzeichnisse mit Baum anzeigen
Wenn Tree nur die Verzeichniseinträge generieren soll, ist dies mit dem Parameter -d wie folgt möglich:

 Baum -d 

18-How-to-work-with-files-using-the-command-Tree-on-Linux.png

Den vollständigen Pfad der Dateien finden Sie in Tree
Der Tree-Befehl gibt uns die Möglichkeit, das Präfix des vollständigen Pfads für die Dateien im Verzeichnis mit dem -f-Parameter zu drucken:

 Baum -f 

19-How-to-work-with-files-using-the-command-Tree-in-Linux.png

Steuern Sie die Dimension des Ergebnisses mit Tree
In einigen Fällen ist es möglich, dass das generierte Ergebnis extrem lang ist. Mit tree können wir die Tiefe des Verzeichnisbaums für seine Ausgabe steuern. Dazu müssen wir den Parameter -L verwenden, der einen numerischen Wert erfordert, der die zulässige Tiefe des Verzeichnisses angibt:

 Baum -d -L 2 

20-'Steuere-die-Dimension-des-Ergebnisses-mit-Tree'.png

Verwenden Sie bei Tree selektive Namen
Mit dem Parameter -l können bestimmte Wörter aus den von Tree generierten Ergebnissen ausgeschlossen werden. Beispielsweise können wir die folgende Zeile ausführen, um Ergebnisse zu generieren, jedoch ohne den Begriff Android:

 Baum -d -I * Android 

21-'Namen-selektiv-mit-Baum'.png

See also  Ubuntu, Tipps & fortgeschrittene Tricks 1/2

10. Parameter, die mit dem Tree-Befehl unter Linux verwendet werden sollen

Mit Tree zu verwendende Parameter
Als nächstes erklärt TechnoWikis die verfügbaren Parameter für Tree:

  • -a: Alle Dateien drucken. Beachten Sie, dass der Baum standardmäßig keine versteckten Dateien druckt.
  • -d: Nur die Verzeichnisse auflisten.
  • -l: Setzen Sie die symbolischen Links fort, wenn sie auf Verzeichnisse verweisen, und simulieren Sie Verzeichnisse.
  • -f: Gibt das Präfix des vollständigen Pfades der Objekte aus.
  • -x: Bleibt allein im aktuellen Dateisystem.
  • -L Level: Ermöglicht die Festlegung der maximalen Visualisierungstiefe des Verzeichnisbaums im Ergebnis.
  • -R: Handelt rekursiv, indem der Baum in den Verzeichnissen jeder Ebene gekreuzt wird und in jedem von ihnen ausgeführt wird. wieder der Baum durch Hinzufügen von -o 00Tree.html.
  • -P Muster (Muster): Listet nur die Dateien auf, die mit dem Platzhaltermuster übereinstimmen.
  • -I Muster: Die Dateien, die mit dem Platzhaltermuster übereinstimmen, werden nicht aufgelistet.
  • –matchdirs Diese Option gibt ein Übereinstimmungsmuster an, mit dem das Muster nur auf Verzeichnisnamen angewendet werden kann.
  • –prune: Dieser Parameter entfernt leere Verzeichnisse aus der Ausgabe.
  • –noreport: Ignoriert das Drucken des Datei- und Verzeichnisberichts am Ende der Liste des ausgeführten Baums.

Allgemeine Baumoptionen
Dies sind die allgemein verfügbaren Optionen von Tree, aber wir haben auch exklusive Parameter für die Dateien. Dies sind:

  • -q: Druckt nicht druckbare Zeichen in Dateinamen.
  • -N: Druckt nicht druckbare Zeichen.
  • -Q: Seine Funktion besteht darin, die Namen der Dateien in Anführungszeichen zu setzen.
  • -p: Gibt den Dateityp und die Berechtigungen für jede Datei im Verzeichnis aus.
  • -u: Gibt den Benutzernamen oder die UID der Datei aus.
  • -s: Gibt die Größe jeder Datei in Bytes aus, genau wie ihr Name.
  • -g Gibt den Namen der Gruppe oder die GID der Datei aus.
  • -h: Es dient dazu, die Größe jeder Datei für den Benutzer leserlich auszudrucken.
  • –du: Führt in jedem Verzeichnis einen Bericht über seine Größe aus, einschließlich der Größe aller seiner Dateien und Unterverzeichnisse.
  • – ja: Für die Bereitstellung der Dateigröße werden Potenzen von 1000 (SI-Einheiten) verwendet.
  • -D: Gibt das Datum der letzten Änderung der Dateien aus.
  • -F: Sie müssen ein “/” für Verzeichnisse, ein “=” für Socket-Dateien, ein “*” für ausführbare Dateien, ein “>” für Türen (Solaris) und ein “|” hinzufügen. für FIFOs.
  • –inodes: Gibt die Inode-Nummer der Datei oder des Verzeichnisses aus.
  • –device: Gibt die Gerätenummer aus, zu der die Datei oder das Verzeichnis im Ergebnis gehört.
  • -v: Sortiert die Ausgabe nach Version.
  • -U: Die Ergebnisse werden nicht sortiert.
  • -r: Sortiert die Ausgabe in umgekehrter Reihenfolge.
  • -t: Sortiert die Ergebnisse nicht alphabetisch, sondern nach dem letzten Änderungszeitpunkt.
  • -S: Aktiviert die Liniengrafik CP437
  • -n: Deaktiviert die Einfärbung des Ergebnisses.
  • -C: Aktivieren Sie die Einfärbung.
  • -X: Aktiviert die XML-Ausgabe.
  • -J: Aktiviert die JSON-Ausgabe.
  • -H baseHREF: Aktiviert die HTML-Ausgabe, einschließlich HTTP-Referenzen.
  • –help: Greifen Sie auf die Hilfe von Tree zu.
  • –version: Zeigt die verwendete Version des Tree-Befehls an.

Mit diesen beiden Befehlen war es möglich, jede Aufgabe, die an den Dateien unter Linux ausgeführt werden sollte, wesentlich integraler zu verwalten, die Aufgaben der Suche oder Verwaltung darauf zu ergänzen und bei Bedarf auf integrale Ergebnisse zuzugreifen.

administrator

Leave a Reply

Your email address will not be published. Required fields are marked *