|
|
| (70 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) |
| Zeile 1: |
Zeile 1: |
| Version 76, 2019-05-30
| | {{DISPLAYTITLE:tr}} |
|
| |
|
| = {{anchor|RefHeadingToc97913328913898}} Linux- tr =
| | '''tr''' - in Texte systematisch Zeichen durch andere Zeichen ersetzen |
|
| |
|
| == {{anchor|RefHeading339881143486078}} Linux- tr == | | == Beschreibung == |
| | Der Befehl tr (von translate = umwandeln oder transliterate = transliterieren) dient dazu, in Texten systematisch Zeichen durch andere Zeichen zu ersetzen. So ist es beispielweise möglich, alle Großbuchstaben einer Datei durch Kleinbuchstaben zu ersetzen oder mehrere aufeinander folgende Leerzeichen durch ein einziges zu ersetzen. Für komplexere Ersetzungen, beispielsweise für ganze Wörter, empfiehlt sich das wesentlich mächtigere [https://wiki.ubuntuusers.de/sed/ sed]. |
|
| |
|
| Der Befehl tr (von '''tr'''anslate = umwandeln oder '''tr'''ansliterate = transliterieren) dient dazu, in Texten systematisch Zeichen durch andere Zeichen zu ersetzen. So ist es beispielweise möglich, alle Großbuchstaben einer Datei durch Kleinbuchstaben zu ersetzen oder mehrere aufeinander folgende Leerzeichen durch ein einziges zu ersetzen. Für komplexere Ersetzungen, z.B. für ganze Wörter, empfiehlt sich das wesentlich mächtigere [https://wiki.ubuntuusers.de/sed/ sed].
| | tr ist ein [https://de.wikipedia.org/wiki/Unix-Kommando Unix-Kommando], dessen Name eine Abkürzung für translate (deutsch: übersetzen) ist, das bestimmte Zeichen aus einem Datenstrom ersetzt oder entfernt. |
|
| |
|
| === {{anchor|RefHeadingToc6371523260012}} Aufruf ===
| | Das Werkzeug liest den Datenstrom der [https://de.wikipedia.org/wiki/Standardeingabe Standardeingabe], schreibt auf die [https://de.wikipedia.org/wiki/Standardausgabe Standardausgabe] und benötigt je nach Modus ein (Löschen und Komprimieren) oder zwei (Ersetzen) Argumente. |
|
| |
|
| Die allgemeine Syntax lautet [https://wiki.ubuntuusers.de/tr/#source-1 [1]]:
| | Sollen Zeichen ersetzt werden, werden zwei Argumente benötigt, zuerst die zu ersetzenden Zeichen, im zweiten die neuen. |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr OPTION ZEICHENFOLGE1 ZEICHENFOLGE2 </div>
| | Abhängig von der Art der Arbeit, die Sie auf der Kommandozeile unter Linux erledigen, können Sie ein Dienstprogramm wünschen, das als Schweizer Taschenmesser für die schnelle Textbearbeitung fungieren kann. Gerne gibt es ein Tool namens tr, das sich für diese Rolle qualifiziert. In diesem Tutorial werden wir die Grundlagen von tr anhand einiger leicht verständlicher Beispiele diskutieren. |
|
| |
|
| <tt>tr</tt> kennt folgende Optionen:
| | Aber bevor wir das tun, ist es erwähnenswert, dass alle Beispiele in diesem Artikel auf einem Ubuntu 18.04 LTS-Rechner getestet wurden. |
|
| |
|
| | tr is a very useful UNIX command. It is used to transform string or delete characters from the string. Various type of transformation can be done by using this command, such as searching and replacing text, transforming string from uppercase to lowercase or vice versa, removing repeated characters from the string und weitere The command can be used for some complicated transformation also. The different uses of tr command are shown in this tutorial. |
|
| |
|
| {| style="border-spacing:0;margin:auto;width:17.501cm;"
| | So erklärt es die Man Page des Tools: |
| |- style="border:none;padding:0.049cm;"
| |
| | colspan="2" | Optionen von <tt>tr</tt>
| |
| |- style="border:none;padding:0.049cm;"
| |
| || Option
| |
| || Beschreibung
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>-c</tt>, <tt>-C</tt> oder <tt>--complement</tt>
| |
| || Komplement der angegebenen Zeichenfolge
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>-d</tt> oder <tt>--delete</tt>
| |
| || Löschen (nicht Ersetzen) von Zeichen
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>-s</tt> oder <tt>--squeeze-repeats</tt>
| |
| || Mehrere identische aufeinanderfolgende Zeichen durch ein einzelnes ersetzen
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>-t</tt> oder <tt>--truncate-set1</tt>
| |
| || Beschneide zunächst den ersten Datensatz auf die Länge des zweiten Datensatzes
| |
| |-
| |
| |}
| |
| Weitere Optionen sind der [https://wiki.ubuntuusers.de/man/ Manpage] zu entnehmen.
| |
|
| |
|
| Von <tt>tr</tt> werden folgende Angaben als Befehle interpretiert:
| | Translate, squeeze, and/or delete characters from standard input, writing to standard output. |
|
| |
|
| | == Anwendungen == |
| | === Einfaches Beispiel === |
| | Ersetzen eines Buchstabens durch einen anderen |
| | echo Maus | tr M H |
| | Haus |
|
| |
|
| {| style="border-spacing:0;margin:auto;width:17.501cm;"
| | Mit folgendem Befehl werden Groß- in Kleinbuchstaben umgewandelt: |
| |- style="border:none;padding:0.049cm;"
| | echo 'FLÜSTERN' | tr A-ZÄÖÜ a-zäöü |
| | colspan="2" | Von <tt>tr</tt> interpretierte Befehlssequenzen | |
| |- style="border:none;padding:0.049cm;"
| |
| || Option
| |
| || Beschreibung
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>\\</tt>
| |
| || Backslash
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>\b</tt>
| |
| || Rücktaste
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>\n</tt>
| |
| || Zeilenumbruch
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>\t</tt>
| |
| || Horizontaler Tab
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>ZEICHEN1-ZEICHEN 2</tt>
| |
| || Alle Zeichen von ZEICHEN 1 bis ZEICHEN2
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>[:alpha:]</tt>
| |
| || Alle Buchstaben
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>[:blank:]</tt>
| |
| || Alle horizontalen Leerzeichen
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>[:digit:]</tt>
| |
| || Alle Zahlen
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>[:lower:]</tt>
| |
| || Alle Kleinbuchstuben
| |
| |- style="border:none;padding:0.049cm;"
| |
| || <tt>[:upper:]</tt>
| |
| || Alle Großbuchstaben
| |
| |-
| |
| |}
| |
| Weitere Angaben sind der [https://wiki.ubuntuusers.de/man/ Manpage] zu entnehmen. Man beachte, dass die [https://wiki.ubuntuusers.de/Zsh/ Zsh] die eckigen Klammern z.B. in <tt>[:blank:]</tt> als Wildcard-Parameter interpretiert und sie daher nicht an <tt>tr</tt> weitergibt. Benutzer der Zsh sollten solche Argument daher in einfache oder doppelte Anführungszeichen einschließen.
| |
|
| |
|
| === {{anchor|RefHeadingToc6391523260012}} Beispiele ===
| | oder auch |
| | echo 'FLÜSTERN' | tr [:upper:]ÄÖÜ [:lower:]äöü |
|
| |
|
| Ein einfaches Beispiel ist das Ersetzen eines Buchstabens durch einen anderen:
| | ergibt |
| | | flüstern |
| <div style="margin-left:0cm;margin-right:0cm;">echo Maus | tr M H
| |
| Haus</div> | |
| | |
| Mit folgendem Befehl werden Groß- in Kleinbuchstaben umgewandelt:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'FLÜSTERN' | tr A-ZÄÖÜ a-zäöü </div>
| |
| | |
| oder auch
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'FLÜSTERN' | tr [:upper:]ÄÖÜ [:lower:]äöü </div>
| |
| | |
| ergibt
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">flüstern</div>
| |
|
| |
|
| … und umgekehrt: | | … und umgekehrt: |
| | echo 'schreien' | tr a-zäöü A-ZÄÖÜ |
| | SCHREIEN |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">echo 'schreien' | tr a-zäöü A-ZÄÖÜ
| | Bestimmte Zeichen, hier alle Zahlen in der Datei datei.txt, lassen sich mit der Option <tt>-d</tt> löschen: |
| SCHREIEN</div>
| | tr -d '0-9' < datei.txt |
| | |
| Bestimmte Zeichen, hier alle Zahlen in der Datei '''datei.txt''', lassen sich mit der Option <tt>-d</tt> löschen: | |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr -d '0-9' < datei.txt </div>
| |
| | |
| Soll aus mehrere aufeinanderfolgenden Leerzeichen ein einzelnes gemacht werden, kann man die Option <tt>-s</tt> verwenden:
| |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">echo 'd b' |tr -s ' ' | | Soll aus mehrere aufeinanderfolgenden Leerzeichen ein einzelnes gemacht werden, kann man die Option <tt>-s</tt> verwenden: |
| d b</div> | | echo 'd b' |tr -s ' ' |
| | d b |
|
| |
|
| Um alle Zeichen zu entfernen, die '''nicht''' einer bestimmten Zeichengruppe angehören, kann die Option <tt>-c</tt> benutzt werden. Im folgenden Beispiel werden alle Zeichen entfernt, die keine Buchstaben sind: | | Um alle Zeichen zu entfernen, die nicht einer bestimmten Zeichengruppe angehören, kann die Option <tt>-c</tt> benutzt werden. Im folgenden Beispiel werden alle Zeichen entfernt, die keine Buchstaben sind: |
| | | echo 'Die drei ??? treffen die 12 Geschworenen!' | tr -cd '[:alpha:]' > datei |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'Die drei ??? treffen die 12 Geschworenen!' | tr -cd '[:alpha:]' > datei
| | cat datei |
| cat datei | | DiedreitreffendieGeschworenen |
| DiedreitreffendieGeschworenen</div> | |
|
| |
|
| Mit Hilfe von tr lässt sich ein Text auch sehr leicht [https://de.wikipedia.org/wiki/Rot13 Rot13] chiffrieren und dechiffieren: | | Mit Hilfe von tr lässt sich ein Text auch sehr leicht [https://de.wikipedia.org/wiki/Rot13 Rot13] chiffrieren und dechiffieren: |
| | | echo 'Morgen bringen wir Cäsar um' | tr [a-zA-Z] [n-za-mN-ZA-M] |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'Morgen bringen wir Cäsar um' | tr [a-zA-Z] [n-za-mN-ZA-M]
| | Zbetra oevatra jve Päfne hz |
| Zbetra oevatra jve Päfne hz</div> | |
|
| |
|
| Und wieder zurück: | | Und wieder zurück: |
| | echo 'Zbetra oevatra jve Päfne hz' | tr [a-zA-Z] [n-za-mN-ZA-M] |
| | Morgen bringen wir Cäsar um |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">echo 'Zbetra oevatra jve Päfne hz' | tr [a-zA-Z] [n-za-mN-ZA-M]
| | Um in einer Datei Zeichen zu ändern und das Ergebnis in eine zweite Datei zu schreiben, können [https://wiki.ubuntuusers.de/Shell/Umleitungen/ Umleitungen] eingesetzt werden. Mit dem folgenden Befehl werden alle Vorkommen des Buchstabens a in datei1 in den Buchstaben b umgewandelt und das Ergebnis in datei2 geschrieben: |
| Morgen bringen wir Cäsar um</div>
| | tr a b < datei1 > datei2 |
|
| |
|
| Um in einer Datei Zeichen zu ändern und das Ergebnis in eine zweite Datei zu schreiben, können [https://wiki.ubuntuusers.de/Shell/Umleitungen/ Umleitungen] eingesetzt werden. Mit dem folgenden Befehl werden alle Vorkommen des Buchstabens a in '''datei1''' in den Buchstaben b umgewandelt und das Ergebnis in '''datei2''' geschrieben:
| | Der folgende Befehl entfernt alle Wagenrückläufe ("Carriage Return", mehr unter [https://wiki.ubuntuusers.de/Zeichensatz-Konverter/ Zeichensatz-Konverter]) und konvertiert so eine Datei datei1 vom Windows- in das Unixformat: |
| | tr -d '\r' < datei1 > ausgabedatei |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr a b < datei1 > datei2 </div>
| | Alle mehrfach aufeinander folgenden Zeilenumbrüche ("new line") in datei1 werden in jeweils einen umgewandelt: |
| | tr -s '\n' < datei1 > ausgabedatei |
|
| |
|
| Der folgende Befehl entfernt alle Wagenrückläufe („Carriage Return“, mehr unter [https://wiki.ubuntuusers.de/Zeichensatz-Konverter/ Zeichensatz-Konverter]) und konvertiert so eine Datei '''datei1''' vom Windows- in das Unixformat: | | Der folgende Befehl führt dazu, dass alle kommaseparierten Elemente einer [https://de.wikipedia.org/wiki/CSV_(Dateiformat) CSV]-Datei datei.csv jeweils in einer neuen Zeile erscheinen: |
| | tr ',' '\n' < datei.csv |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr -d '\r' < datei1 > ausgabedatei </div>
| | Beispiel: |
| | $ echo Meyer | tr y i |
| | Meier |
|
| |
|
| Alle mehrfach aufeinander folgenden Zeilenumbrüche („new line“) in '''datei1''' werden in jeweils einen umgewandelt:
| | Es sind mehrfache Ersetzungen einzelner Zeichen auf einmal möglich. Z.B. ersetzt |
| | tr 'abcd' 'jkmn' |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr -s '\n' < datei1 > ausgabedatei </div>
| | alle vorkommenden a durch j, b durch k und weitere |
|
| |
|
| Der folgende Befehl führt dazu, dass alle kommaseparierten Elemente einer [https://de.wikipedia.org/wiki/CSV_(Dateiformat) CSV]-Datei '''datei.csv''' jeweils in einer neuen Zeile erscheinen:
| | Im Alphabet aufeinanderfolgende Zeichen lassen sich dabei mit einem Bindestrich angeben: |
| | tr 'a-d' 'jkmn' |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr ',' '\n' < datei.csv </div>
| | Mit dem Operator s werden alle hintereinander folgenden identischen Zeichen durch ein einzelnes ersetzt. Beispiel: |
| | echo muuuuh | tr -s u |
| | muh |
|
| |
|
| == {{anchor|RefHeadingToc6431523260012}} tr ==
| | Der Operand d löscht alle im ersten Argument angegebenen Zeichen |
| | tr -d '\r' |
|
| |
|
| '''tr''' ist ein [https://de.wikipedia.org/wiki/Unix-Kommando Unix-Kommando], dessen Name eine Abkürzung für ''translate'' (''deutsch:'' übersetzen) ist, das bestimmte Zeichen aus einem Datenstrom ersetzt oder entfernt.
| | wobei \r für ein Carriage Return (Bytewert 13) steht. Mit diesem Befehl wird dieses unter Unix nicht verwendete Umbruchzeichen ersatzlos entfernt. |
|
| |
|
| Das Werkzeug liest den Datenstrom der [https://de.wikipedia.org/wiki/Standardeingabe Standardeingabe], schreibt auf die [https://de.wikipedia.org/wiki/Standardausgabe Standardausgabe] und benötigt je nach Modus ein (Löschen und Komprimieren) oder zwei (Ersetzen) Argumente.
| | Ist ein c angegeben, so gilt die Umkehrung, also hier |
| | tr -cd '[:alnum:]' |
|
| |
|
| Sollen Zeichen ersetzt werden, werden zwei Argumente benötigt, zuerst die zu ersetzenden Zeichen, im zweiten die neuen.
| | wobei der Ausdruck [:alnum:] für alle alphanumerischen Zeichen steht. Somit werden alle nicht alphanumerischen Zeichen entfernt. |
| | |
| Beispiel:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo Meyer | tr y i</div>
| |
| <div style="margin-left:0cm;margin-right:0cm;">Meier</div>
| |
| | |
| Es sind mehrfache Ersetzungen einzelner Zeichen auf einmal möglich. Z.B. ersetzt
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr 'abcd' 'jkmn'</div>
| |
| | |
| alle vorkommenden ''a'' durch ''j'', ''b'' durch ''k'' usw.
| |
| | |
| Im Alphabet aufeinanderfolgende Zeichen lassen sich dabei mit einem Bindestrich angeben:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr 'a-d' 'jkmn'</div>
| |
| | |
| Mit dem Operator ''s'' werden alle hintereinander folgenden identischen Zeichen durch ein einzelnes ersetzt. Beispiel:
| |
| | |
| echo muuuuh | tr -s u
| |
| <div style="margin-left:0cm;margin-right:0cm;">muh</div>
| |
| | |
| Der Operand ''d'' löscht alle im ersten Argument angegebenen Zeichen
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr -d '\r'</div>
| |
| | |
| wobei \r für ein Carriage Return (Bytewert 13) steht. Mit diesem Befehl wird dieses unter Unix nicht verwendete Umbruchzeichen ersatzlos entfernt.
| |
| | |
| Ist ein ''c'' angegeben, so gilt die Umkehrung, also hier
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr -cd '[:alnum:]' </div>
| |
| | |
| wobei der Ausdruck [:alnum:] für alle alphanumerischen Zeichen steht. Somit werden alle nicht alphanumerischen Zeichen entfernt. | |
| | |
| == {{anchor|RefHeadingToc6491523260012}} tr für Anfänger ==
| |
| | |
| Abhängig von der Art der Arbeit, die Sie auf der Kommandozeile unter Linux erledigen, können Sie ein Dienstprogramm wünschen, das als Schweizer Taschenmesser für die schnelle Textbearbeitung fungieren kann. Gerne gibt es ein Tool namens tr, das sich für diese Rolle qualifiziert. In diesem Tutorial werden wir die Grundlagen von tr anhand einiger leicht verständlicher Beispiele diskutieren.
| |
| | |
| Aber bevor wir das tun, ist es erwähnenswert, dass alle Beispiele in diesem Artikel auf einem Ubuntu 18.04 LTS-Rechner getestet wurden.
| |
| | |
| So erklärt es die Man Page des Tools:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">Translate, squeeze, and/or delete characters from standard input, writing to standard output.</div>
| |
| | |
| Und folgendes ist seine Syntax:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr [OPTION]... SET1 [SET2]</div>
| |
| | |
| hier ist, was SET bedeutet:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are:</div>
| |
| <div style="margin-left:0cm;margin-right:0cm;">\NNN character with octal value NNN (1 to 3 octal digits)
| |
| \\ backslash
| |
| \a audible BEL
| |
| \b backspace
| |
| \f form feed
| |
| \n new line
| |
| \r return
| |
| \t horizontal tab
| |
| \v vertical tab</div>
| |
| | |
| === {{anchor|RefHeadingToc6531523260012}} Klein- in Großbuchstaben ===
| |
| | |
| Angenommen, du möchtest den Satz „linux tutorial on howtoforge“ in Großbuchstaben konvertieren, dann ist hier, wie du dies mit tr tun kannst.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'linux tutorial on howtoforge' | tr "[:lower:]" "[:upper:]"</div>
| |
| | |
| Der obige Befehl erzeugte die folgende Ausgabe auf meinem System:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">LINUX TUTORIAL ON HOWTOFORGE</div>
| |
| | |
| === {{anchor|RefHeadingToc6551523260012}} Zusätzliche Räume abstreifen ===
| |
| | |
| Angenommen, Sie haben eine Zeile wie: „HowtoForge ist eine extrem gute Ressource für Linux-Tutorials“. Und die Anforderung ist, zusätzliche Räume von dieser Linie zu entfernen.
| |
| | |
| Hier ist, wie du tr verwenden kannst, um dies zu tun:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge is an extremely good resource for Linux tutorials' | tr -s '[:space:]'</div>
| |
| | |
| Hier ist die Ausgabe:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge is an extremely good resource for Linux tutorials</div>
| |
| | |
| === {{anchor|RefHeadingToc6571523260012}} Text löschen ===
| |
| | |
| Angenommen, Sie möchten die Bindestriche aus der folgenden Zeile löschen: „HowtoForge — ist — ein — extrem — gut — Ressource — für — Linux — Tutorials.“ Dann ist hier, wie Sie dies mit tr tun können.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr -d '-'</div>
| |
| | |
| Es folgt der Output, den es produziert:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge is an extremely good resource for Linux tutorials</div>
| |
| | |
| === {{anchor|RefHeadingToc6591523260012}} Zeichen ersetzen ===
| |
| | |
| Im vorherigen Abschnitt nehmen wir an, dass die Anforderung darin bestand, Bindestriche durch, sagen wir, Punkte zu ersetzen. Dann ist hier, wie du das mit tr machen kannst.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr '-' '.'</div>
| |
| | |
| Es folgt der Output, den es produziert hat:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge .. is .. an .. extremely .. good .. resource .. for .. Linux .. tutorials</div>
| |
| | |
| == {{anchor|RefHeadingToc6631523260012}} tr ==
| |
| | |
| '''tr''' is a very useful UNIX command. It is used to transform string or delete characters from the string. Various type of transformation can be done by using this command, such as searching and replacing text, transforming string from uppercase to lowercase or vice versa, removing repeated characters from the string etc. The command can be used for some complicated transformation also. The different uses of '''tr '''command are shown in this tutorial.
| |
| | |
| '''Syntax:'''
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''tr [option] stringValue1 [stringValue2]'''</div>
| |
| | |
| '''option''' and '''stringValue2''' are optional for '''tr''' command. You can use '''-c, -s''' and '''-d''' option with '''tr '''command to do different types of tasks.
| |
| | |
| === {{anchor|RefHeadingToc6651523260012}} Change case ===
| |
|
| |
|
| | ==== Change case ==== |
| You can change the case of the string very easily by using tr command. To define uppercase, you can use [:upper:] or [A-Z] and to define lowercase you can define [:lower:] or [a-z]. | | You can change the case of the string very easily by using tr command. To define uppercase, you can use [:upper:] or [A-Z] and to define lowercase you can define [:lower:] or [a-z]. |
|
| |
|
| tr command can be used in the following way to convert any string from uppercase to lowercase. | | tr command can be used in the following way to convert any string from uppercase to lowercase. |
| | | tr [:upper:] [:lower:] |
| <div style="margin-left:0cm;margin-right:0cm;">'''tr [:upper:] [:lower:]'''</div>
| |
|
| |
|
| You can use tr command in the following way also to convert any string from lowercase to uppercase. | | You can use tr command in the following way also to convert any string from lowercase to uppercase. |
| | tr a-z A-Z |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''tr a-z A-Z'''</div>
| | Run the following command to convert every small letter of the string,’linuxhint’ into the capital letter. |
| | | $ echo linuxhint | tr [:lower:] [:upper:] |
| Run the following command to convert every small letter of the string,’'''linuxhint'''’ into the capital letter. | |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo linuxhint | tr [:lower:] [:upper:]</div>
| |
| | |
| You can apply tr command for converting the content of any text file from upper to lower or lower to upper. Suppose, you have text file named, '''items.txt '''with the following contents.# Monitor
| |
| # Keyboard
| |
| # Mouse
| |
| # Scanner
| |
| # HDD
| |
| | |
|
| |
|
| | You can apply tr command for converting the content of any text file from upper to lower or lower to upper. Suppose, you have text file named, items.txt with the following contents. |
| | # Monitor |
| | # Keyboard |
| | # Mouse |
| | # Scanner |
| | # HDD |
|
| |
|
| Run the following commands from the terminal to display the content of items.txt and the output of tr command after converting the content of that file from lower to upper case. The following tr command will not modify the original content of the file. | | Run the following commands from the terminal to display the content of items.txt and the output of tr command after converting the content of that file from lower to upper case. The following tr command will not modify the original content of the file. |
| | $ cat items.txt |
| | $ tr a-z A-Z < items.txt |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">$ cat items.txt
| | You can run the following command to store the output of the tr command into another file named ‘output.txt’. |
| $ tr a-z A-Z < items.txt</div> | | $ tr [:upper:] [:lower:] < items.txt > output.txt |
| | $ cat output.txt |
|
| |
|
| You can run the following command to store the output of the '''tr''' command into another file named ‘'''output.txt'''’.
| | ==== Translate character ==== |
| | tr command can be used to search and replace any particular character from any text. The following command is used to convert each space of the text, "Welcome to Linuxhint" by newline (\n). |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">$ tr [:upper:] [:lower:] < items.txt > output.txt
| | $ echo "Welcome To Linuxhint" | tr [:space:] '\n' |
| $ cat output.txt</div>
| |
|
| |
|
| === {{anchor|RefHeadingToc6671523260012}} Translate character === | | ==== -c option ==== |
| | tr command can be used with -c option to replace those characters with the second character that don’t match with the first character value. In the following example, tr command is used to search those characters in the string ‘bash’ that don’t match with the character ‘b’ and replace them by ‘a’. The output is ‘baaaa’. Four characters are converted here. These are ,’a’,’s’,’h’ and ‘\n’. |
| | $ echo "bash" | tr -c 'b' 'a' |
|
| |
|
| tr command can be used to search and replace any particular character from any text. The following command is used to convert each space of the text, “'''Welcome to Linuxhint'''” by newline (\n). | | ==== -s option ==== |
| | tr command uses -s option for search and replace any string from a text. In the following example, space (‘ ‘) is replaced by tab (‘\t’). |
| | $ echo "BASH Programming" | tr -s ' ' '\t' |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "Welcome To Linuxhint" | tr [:space:] '\n'</div>
| | You can use both -c and -s options together with tr command. In the following example, the range of small letter is used as the first string value. For -c option, tr command will search and replace each capital letter by newline (‘\n’) of the file, items.txt and store the output of the command in the file, output.txt. |
| | | $ cat items.txt |
| === {{anchor|RefHeadingToc6691523260012}} –c option ===
| |
| | |
| tr command can be used with -c option to replace those characters with the second character that don’t match with the first character value. In the following example, tr command is used to search those characters in the string ‘'''bash'''’ that don’t match with the character ‘'''b'''’ and replace them by ‘'''a'''’. The output is ‘'''baaaa'''’. Four characters are converted here. These are ,’a’,’s’,’h’ and ‘\n’.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "bash" | tr -c 'b' 'a'</div>
| |
| | |
| === {{anchor|RefHeadingToc6711523260012}} –s option ===
| |
| | |
| tr command uses '''–s '''option for search and replace any string from a text. In the following example, space (‘ ‘) is replaced by tab (‘\t’).
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "BASH Programming" | tr -s ' ' '\t'</div>
| |
| | |
| You can use both -c and -s options together with tr command. In the following example, the range of small letter is used as the first string value. For –c option, tr command will search and replace each capital letter by newline (‘\n’) of the file, '''items.txt''' and store the output of the command in the file, '''output.txt'''. | |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ cat items.txt
| |
| $ tr -cs [a-z] "\n" < items.txt > output.txt | | $ tr -cs [a-z] "\n" < items.txt > output.txt |
| $ cat output.txt</div> | | $ cat output.txt |
| | |
| === {{anchor|RefHeadingToc6731523260012}} –d option ===
| |
| | |
| '''-d''' option used with tr command to search and delete any character or string from a text. In the following example, tr command will search ‘'''P'''’, ‘'''y’''' and ‘'''t'''’ in the string “'''Python is a Programming language”''' and delete those characters.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "Python is a Programming language" | tr -d 'Pyt'</div>
| |
| | |
| '''-c''' option can be used with '''–d''' option in the tr command to complement the search like precious –cs command. In the following example, tr command with '''–cd''' will search all non-digit characters from the string, “'''Phone No: 985634854'''” and delete them.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "Phone No: 985634854" | tr -cd '0-9'</div>
| |
| | |
| In a similar way, you can run use '''-cd''' option in '''tr''' command like the following command to remove the non-printable characters from a file. No nonprintable character exists in '''items.txt'''. So the output will be the same as the file content.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr -cd "[:print:]" < items.txt</div>
| |
| | |
| === {{anchor|RefHeadingToc15501523260012}} Conclusion ===
| |
| | |
| The basic uses of '''tr '''command are explained here by using various examples. Hope, this tutorial will help you to learn the purposes of using this command.
| |
| | |
| === {{anchor|RefHeadingToc6751523260012}} Linux tr command ===
| |
| | |
| Depending on the kind of work you do on the command line in Linux, you may want a utility that can act as a Swiss army knife of quick text editing. Gladly, there exists a tool dubbed tr, which qualifies for this role. In this tutorial, we will discuss the basics of tr using some easy to understand examples.
| |
| | |
| Here's how the tool's man page explains it:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">Translate, squeeze, and/or delete characters from standard input, writing to standard output.</div>
| |
| | |
| And following is its syntax:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">tr [OPTION]... SET1 [SET2]</div>
| |
| | |
| here's what SET means:
| |
|
| |
|
| <tt>SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are:</tt>
| | ==== -d option ==== |
| | -d option used with tr command to search and delete any character or string from a text. In the following example, tr command will search ‘P’, ‘y’ and ‘t’ in the string "Python is a Programming language" and delete those characters. |
| | $ echo "Python is a Programming language" | tr -d 'Pyt' |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;"> \NNN character with octal value NNN (1 to 3 octal digits)
| | -c option can be used with -d option in the tr command to complement the search like precious -cs command. In the following example, tr command with -cd will search all non-digit characters from the string, "Phone No: 985634854" and delete them. |
| \\ backslash | | $ echo "Phone No: 985634854" | tr -cd '0-9' |
| \a audible BEL
| |
| \b backspace
| |
| \f form feed
| |
| \n new line
| |
| \r return
| |
| \t horizontal tab
| |
| \v vertical tab</div>
| |
|
| |
|
| === {{anchor|RefHeadingToc6811523260012}} lower case to upper case ===
| | In a similar way, you can run use -cd option in tr command like the following command to remove the non-printable characters from a file. No nonprintable character exists in items.txt. So the output will be the same as the file content. |
| | $ tr -cd "[:print:]" < items.txt |
|
| |
|
| | ==== lower case to upper case ==== |
| Suppose you want to convert the sentence "linux tutorial on howtoforge" to uppercase, then here's how you can do this using tr. | | Suppose you want to convert the sentence "linux tutorial on howtoforge" to uppercase, then here's how you can do this using tr. |
| | | echo 'linux tutorial on howtoforge' | tr "[:lower:]" "[:upper:]" |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'linux tutorial on howtoforge' | tr "[:lower:]" "[:upper:]"</div>
| |
|
| |
|
| The above command produced the following output on my system: | | The above command produced the following output on my system: |
| | LINUX TUTORIAL ON HOWTOFORGE |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">LINUX TUTORIAL ON HOWTOFORGE</div>
| | ==== Strip extra spaces ==== |
| | | Suppose you have a line like: "HowtoForge is an extremely good resource for Linux tutorials". And the requirement is to strip extra spaces from this line. |
| === {{anchor|RefHeadingToc6831523260012}} Strip extra spaces === | |
| | |
| Suppose you have a line like: "HowtoForge is an extremely good resource for Linux tutorials". And the requirement is to strip extra spaces from this line. | |
|
| |
|
| Here's how you can use tr to do this: | | Here's how you can use tr to do this: |
| | $ '''echo 'HowtoForge is an extremely good resource for Linux tutorials' | tr -s '[:space:]' ''' |
| | HowtoForge is an extremely good resource for Linux tutorials |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge is an extremely good resource for Linux tutorials' | tr -s '[:space:]'</div>
| | ==== Delete text ==== |
| | |
| Here's the output:
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge is an extremely good resource for Linux tutorials</div>
| |
| | |
| === {{anchor|RefHeadingToc6851523260012}} Delete text === | |
| | |
| Suppose you want to delete the hyphens from the following line: "HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials." Then here's how you can do this using tr. | | Suppose you want to delete the hyphens from the following line: "HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials." Then here's how you can do this using tr. |
| | | echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr -d '-' |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr -d '-'</div>
| |
|
| |
|
| Following is the output it produces: | | Following is the output it produces: |
| | HowtoForge is an extremely good resource for Linux tutorials |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge is an extremely good resource for Linux tutorials</div>
| | ==== Replace characters ==== |
| | |
| === {{anchor|RefHeadingToc6871523260012}} Replace characters === | |
|
| |
|
| In the previous section, suppose the requirement was to replace hyphens with, let's say, dots. Then here's how you can do that using tr. | | In the previous section, suppose the requirement was to replace hyphens with, let's say, dots. Then here's how you can do that using tr. |
| | | echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr '-' '.' |
| <div style="margin-left:0cm;margin-right:0cm;">echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr '-' '.'</div>
| |
|
| |
|
| Following is the output it produced: | | Following is the output it produced: |
| | HowtoForge .. is .. an .. extremely .. good .. resource .. for .. Linux .. tutorials |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">HowtoForge .. is .. an .. extremely .. good .. resource .. for .. Linux .. tutorials</div>
| | ==== POSIX Character set ==== |
| | | [:digit:] Only the digits 0 to 9 |
| == {{anchor|RefHeadingToc6911523260012}} tr examples ==
| |
| | |
| Along with [https://www.linuxnix.com/sedsteam-editor-explained-detail-linuxunix/ the Linux sed command], the tr command stands for translate is used to provide a level of swapping or translation, suppression or deletion of files. The tr command just translates one character to another character. In this article, we’ll share a couple of examples demonstrating some exciting things that we can do with the tr command.
| |
| | |
| === {{anchor|RefHeadingToc6931523260012}} Basic syntax ===
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''tr [OPTION] [SET1] [SET2]'''</div>
| |
| | |
| SET1 denotes what we wish to translate in the input file, and SET2 means what we want to convert SET1 as the output of the translation. So the sets can be a single character or multiple characters.
| |
| | |
| '''Example1:''' Suppose you just want to replace a in “sahil suri” with b we can use tr sets. We use [https://www.linuxnix.com/9-linux-echo-command-examples/ echo command] to send “sahil suri” to tr command. The tr command by default is not able to read data stream. We use [https://www.linuxnix.com/linuxunix-redirection-operatorsfile-descriptors-explained-examples/ Linux inbuilt redirection operators] to feed data to tr command.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'a' 'b'
| |
| sbhil suri'''</div>
| |
| | |
| '''Example2:''' Suppose if you want to replace multiple characters one after the other then we can use below-set examples. Suppose you want to replace a with b, r with x and i with z, below is the case you are looking at.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'ari' 'bxz'
| |
| sbhzl suxz'''</div>
| |
| | |
| '''Note:''' Make sure that first set and second set have the same number of characters. For example, i is just replaced with z as we don’t have the third character on the list below.
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'ari' 'bz'
| |
| sbhzl suzz'''</div>
| |
| | |
| Similarly, we can use sets to convert multiple letters. Some of the sets tr supports are as below.
| |
| | |
| === {{anchor|RefHeadingToc6951523260012}} POSIX Character set === | |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''[:digit:] Only the digits 0 to 9
| |
| [:alnum:] Any alphanumeric character | | [:alnum:] Any alphanumeric character |
| [:alpha:] Any alpha character A to Z or a to z. | | [:alpha:] Any alpha character A to Z or a to z. |
| [:blank:] Space and TAB characters only. | | [:blank:] Space and TAB characters only. |
| [:xdigit:] Hexadecimal notation 0-9, A-F, a-f. | | [:xdigit:] Hexadecimal notation 0-9, A-F, a-f. |
| [:punct:] Punctuation symbols . , ” ‘ ? ! ; : # $ % & ( ) * + – / < > = @ [ ] \ ^ _ { } | ~ | | [:punct:] Punctuation symbols . , " ‘ ? ! ; : # $ % & ( ) * + - / < > = @ [ ] \ ^ _ { } | ~ |
| [:print:] Any printable character. | | [:print:] Any printable character. |
| [:space:] Any whitespace characters (space, tab, NL, FF, VT, CR). Many system abbreviates as \s. | | [:space:] Any whitespace characters (space, tab, NL, FF, VT, CR). Many system abbreviates as \s. |
| Zeile 449: |
Zeile 195: |
| [:upper:] Any alpha character A to Z. | | [:upper:] Any alpha character A to Z. |
| [:lower:] Any alpha character a to z. | | [:lower:] Any alpha character a to z. |
| [:cntrl:] Control Characters NL CR LF TAB VT FF NUL SOH STX EXT EOT ENQ ACK SO SI DLE DC1 DC2 DC3 DC4 NAK SYN ETB CAN EM SUB ESC IS1 IS2 IS3 IS4 DEL.'''</div> | | [:cntrl:] Control Characters NL CR LF TAB VT FF NUL SOH STX EXT EOT ENQ ACK SO SI DLE DC1 DC2 DC3 DC4 NAK SYN ETB CAN EM SUB ESC IS1 IS2 IS3 IS4 DEL. |
| | |
| === {{anchor|RefHeadingToc6971523260012}} Character sets ===
| |
| | |
| # '''a-z To represent complete lower case alphabets'''
| |
| # '''A-Z to represent upper case alphabets'''
| |
| # '''0-9 To describe the set of numbers.'''
| |
|
| |
|
| | ==== Character sets ==== |
| | # a-z To represent complete lower case alphabets |
| | # A-Z to represent upper case alphabets |
| | # 0-9 To describe the set of numbers. |
|
| |
|
| | | ==== lower to upper case. ==== |
| === {{anchor|RefHeadingToc32401523260012}} lower to upper case. === | | echo "sahil suri" | tr 'a-z' 'A-Z' |
| | | SAHIL SURI |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'a-z' 'A-Z'
| |
| SAHIL SURI'''</div> | |
|
| |
|
| The tr command mentioned above implies to translate all alphabets in lowercase denoted by ‘a-z’ into alphabets in upper case denoted by ‘A-Z’ | | The tr command mentioned above implies to translate all alphabets in lowercase denoted by ‘a-z’ into alphabets in upper case denoted by ‘A-Z’ |
|
| |
|
| === {{anchor|RefHeadingToc32421523260012}} Convert all characters in input from upper to lower case === | | ==== Convert all characters in input from upper to lower case ==== |
| | | echo "SAHIL SURI" | tr 'A-Z' 'a-z' |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "SAHIL SURI" | tr 'A-Z' 'a-z'
| | sahil suri |
| sahil suri'''</div> | |
| | |
| === {{anchor|RefHeadingToc32441523260012}} Translate only particular characters from lower to upper case ===
| |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'shlr' 'SHLR'
| | ==== Translate only particular characters from lower to upper case ==== |
| SaHiL SuRi'''</div> | | echo "sahil suri" | tr 'shlr' 'SHLR' |
| | SaHiL SuRi |
|
| |
|
| In the previous two examples, we gave ranges, but we can use distinct characters as well as shown in the above example. | | In the previous two examples, we gave ranges, but we can use distinct characters as well as shown in the above example. |
|
| |
|
| === {{anchor|RefHeadingToc32461523260012}} Use multiple ranges === | | ==== Use multiple ranges ==== |
| | echo "sahil suri" | tr 'a-dr-z' 'A-DR-Z' |
| | SAhil SURi |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "sahil suri" | tr 'a-dr-z' 'A-DR-Z'
| | ==== translate individual characters as well ==== |
| SAhil SURi'''</div>
| |
|
| |
|
| === {{anchor|RefHeadingToc32481523260012}} translate individual characters as well === | | ===== Translate braces into parenthesis ===== |
| | echo "{ Hello World }" > infile |
| | tr '{}' '()' < infile > outfile |
| | cat outfile |
| | ( Hello World ) |
|
| |
|
| ==== Translate braces into parenthesis ==== | | ==== Translate spaces to new lines. ==== |
| | We use infile as our test file. Use [https://www.linuxnix.com/20-linuxunix-cat-command-examples/ cat command] to display the content of the file. |
| | cat infile |
| | solaris linux aix |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "{ Hello World }" > infile'''
| | cat infile | tr " " "\n" |
| '''tr '{}' '()' < infile > outfile''' | | solaris |
| '''cat outfile''' | | linux |
| '''( Hello World )'''</div> | | aix |
|
| |
|
| === {{anchor|RefHeadingToc32501523260012}} Translate spaces to new lines. ===
| | cat infile | tr "[:space:] " "\n" |
| | solaris |
| | linux |
| | aix |
|
| |
|
| We use infile as our test file. Use [https://www.linuxnix.com/20-linuxunix-cat-command-examples/ cat command] to display the content of the file.
| | While using translate, you may use " " or [:space:] to represent white space. I find the first option easier to type. |
|
| |
|
| '''cat infile'''
| | ==== Replace white space ==== |
| '''solaris linux aix''' | | cat infile | tr " " ":" |
| '''cat infile | tr " " "\n"'''
| | solaris:linux:aix |
| '''solaris''' | |
| '''linux'''
| |
| '''aix'''
| |
| '''cat infile | tr "[:space:] " "\n"'''
| |
| '''solaris'''
| |
| '''linux'''
| |
| '''aix'''
| |
|
| |
|
| While using translate, you may use ” ” or [:space:] to represent white space. I find the first option easier to type.
| | cat infile | tr " " "|" |
| | solaris|linux|aix |
|
| |
|
| === {{anchor|RefHeadingToc32521523260012}} Replace white space === | | ==== Replace multiple occurrences ==== |
|
| |
|
| '''cat infile | tr " " ":"
| | ===== ... with a single appearance of the character. ===== |
| solaris:linux:aix'''
| |
| '''cat infile | tr " " "|"
| |
| solaris|linux|aix'''
| |
|
| |
|
| === {{anchor|RefHeadingToc33941523260012}} Replace multiple occurrences ===
| | In below example, we replaced numerous spaces with separate space. |
|
| |
|
| ==== ... with a single appearance of the character. ====
| | cat infile |
| | solaris linux aix |
|
| |
|
| In below example, we replaced numerous spaces with separate space.
| | tr -s " " < infile |
| | solaris linux aix |
|
| |
|
| '''cat infile
| | In the above case, we used the tr command with -s option to indicate a squeeze operation.This replaces multiple occurrences of a character with a single appearance of the same character. |
| solaris linux aix'''
| |
| '''tr -s " " < infile
| |
| solaris linux aix'''
| |
|
| |
|
| In the above case, we used the tr command with -s option to indicate a squeeze operation.This replaces multiple occurrences of a character with a single appearance of the same character.
| | ===== … with a different character ===== |
|
| |
|
| ==== {{anchor|RefHeadingToc32561523260012}} … with a different character ====
| | cat infile |
| | solaris linux aix |
|
| |
|
| '''cat infile
| | tr -s " " ";" < infile |
| solaris linux aix''' | | solaris;linux;aix |
| '''tr -s " " ";" < infile
| |
| solaris;linux;aix''' | |
|
| |
|
| The above tr command squeezes multiple occurrences of white space into one semicolon character. | | The above tr command squeezes multiple occurrences of white space into one semicolon character. |
|
| |
|
| === {{anchor|RefHeadingToc32581523260012}} Delete all occurances of a character. === | | ==== Delete all occurances of a character. ==== |
|
| |
|
| To delete occurrences of a character we use the -d option with the tr command followed by the character to be removed. | | To delete occurrences of a character we use the -d option with the tr command followed by the character to be removed. |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "linuxunix" | tr -d 'u'
| | echo "linuxunix" | tr -d 'u' |
| linxnix'''</div> | | linxnix |
| | |
| The above command removes all occurrences of the '''character u''' from the input string.
| |
|
| |
|
| === {{anchor|RefHeadingToc32601523260012}} Remove all digits from the input. ===
| | The above command removes all occurrences of the character u from the input string. |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "james bond 007" | tr -d '0-9'
| | ==== Remove all digits from the input. ==== |
| james bond'''</div> | | echo "james bond 007" | tr -d '0-9' |
| | james bond |
|
| |
|
| === {{anchor|RefHeadingToc41681523260012}} Remove all alphabets from the input. === | | ==== Remove all alphabets from the input. ==== |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "james bond 007" | tr -d 'a-zA-Z'
| | echo "james bond 007" | tr -d 'a-zA-Z' |
| 007'''</div> | | 007 |
| | |
| === {{anchor|RefHeadingToc32621523260012}} Remove characters except the given ===
| |
|
| |
|
| | ==== Remove characters except the given ==== |
| We used -d option to delete characters we mentioned from the input. We may use the -c option with the -d option to delete all characters except those that we mention. | | We used -d option to delete characters we mentioned from the input. We may use the -c option with the -d option to delete all characters except those that we mention. |
| | | echo "solaris linux hp-ux" | tr -cd 'slh' |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "solaris linux hp-ux" | tr -cd 'slh'
| | slslh |
| slslh'''</div> | |
|
| |
|
| The above tr command removed all characters including the new line leaving behind the characters s,l and h which we mentioned to be removed. Using the -c option is also sometimes referred to as complimenting the set. | | The above tr command removed all characters including the new line leaving behind the characters s,l and h which we mentioned to be removed. Using the -c option is also sometimes referred to as complimenting the set. |
|
| |
|
| === {{anchor|RefHeadingToc32641523260012}} Remove all non-alphanumeric and space === | | ==== Remove all non-alphanumeric and space ==== |
| | | echo "solaris | linux 007 ; hp-ux :::: aix" | tr -cd "[:alpha:][:space:][:digit:]" |
| '''echo "solaris | linux 007 ; hp-ux :::: aix" | tr -cd "[:alpha:][:space:][:digit:]"
| | solaris linux 007 hpux aix |
| solaris linux 007 hpux aix''' | |
|
| |
|
| This example could prove to be especially useful when dealing with a file having a lot of junk characters. | | This example could prove to be especially useful when dealing with a file having a lot of junk characters. |
|
| |
|
| === {{anchor|RefHeadingToc32661523260012}} Translate non-alphanumeric characters === | | ==== Translate non-alphanumeric characters into a single newline character ==== |
| | | echo "james bond 007" | tr -cs 'a-zA-Z0-9' '\n' |
| ==== into a single newline character ====
| |
| | |
| <div style="margin-left:0cm;margin-right:0cm;">'''echo "james bond 007" | tr -cs 'a-zA-Z0-9' '\n'
| |
| james | | james |
| bond | | bond |
| 007'''</div> | | 007 |
|
| |
|
| === {{anchor|RefHeadingToc32681523260012}} Join lines in a file into a single === | | ==== Join lines in a file into a single ==== |
| | | cat infile |
| '''cat infile
| |
| solaris | | solaris |
| linux | | linux |
| aix''' | | aix |
| '''tr -s '\n' ' ' < infile
| | |
| solaris linux aix [root@linuxnix ~]#''' | | tr -s '\n' ' ' < infile |
| | solaris linux aix [root@linuxnix ~]# |
|
| |
|
| The above tr command squeezes the new line character into a single space character.This option can be useful when attempting to consolidate scattered text in a file. | | The above tr command squeezes the new line character into a single space character.This option can be useful when attempting to consolidate scattered text in a file. |
|
| |
|
| This concludes our exploration of the tr command. Please consider reading our articles about [https://www.linuxnix.com/category/Programming/Sed/ sed] which is another utility that provides most of the translation features we discussed in the above examples and a lot more. | | This concludes our exploration of the tr command. Please consider reading our articles about [https://www.linuxnix.com/category/Programming/Sed/ sed] which is another utility that provides most of the translation features we discussed in the above examples and a lot more. |
|
| |
|
| == {{anchor|RefHeadingToc6991523260012}} Linux tr command == | | ==== Problembehebung ==== |
|
| |
|
| On [https://www.computerhope.com/jargon/u/unix-like.htm Unix-like] operating systems, the '''tr''' command automatically translates (substitutes, or maps) one set of [https://www.computerhope.com/jargon/c/charact.htm characters] to another.
| | == Aufruf == |
| | Und folgendes ist seine Syntax: |
|
| |
|
| This document covers the [https://www.computerhope.com/jargon/g/gnu.htm GNU]/[https://www.computerhope.com/jargon/l/linux.htm Linux] version of '''tr'''.
| | tr [OPTION]... SET1 [SET2] |
|
| |
|
| The '''tr''' utility copies the [https://www.computerhope.com/jargon/s/stdin.htm standard input] to the standard output with substitution or deletion of selected characters.
| | hier ist, was SET bedeutet: |
|
| |
|
| === {{anchor|RefHeadingToc7031523260012}} Syntax ===
| | SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are: \NNN character with octal value NNN (1 to 3 octal digits) |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr [-Ccsu] ''string1'' ''string2''</div>
| | \\ backslash |
| | \a audible BEL |
| | \b backspace |
| | \f form feed |
| | \n new line |
| | \r return |
| | \t horizontal tab |
| | \v vertical tab |
|
| |
|
| In this form, the characters in the [https://www.computerhope.com/jargon/s/string.htm string] ''string1'' are translated into the characters in ''string2'' where the first character in ''string1'' is translated into the first character in ''string2'' and so on. If ''string1'' is longer than ''string2'', the last character found in ''string2'' is duplicated until string1 is exhausted. | | Depending on the kind of work you do on the command line in Linux, you may want a utility that can act as a Swiss army knife of quick text editing. Gladly, there exists a tool dubbed tr, which qualifies for this role. In this tutorial, we will discuss the basics of tr using some easy to understand examples. |
| | |
| | Here's how the tool's man page explains it: |
| | |
| | Translate, squeeze, and/or delete characters from standard input, writing to standard output. |
| | |
| | And following is its syntax: |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr [-Ccu] -d ''string1''</div>
| | tr [OPTION]... SET1 [SET2] |
|
| |
|
| In this form, the characters in ''string1'' are deleted from the input.
| | here's what SET means: |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr [-Ccu] -s ''string1''</div> | | <tt>SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are:</tt> |
|
| |
|
| In this form, the characters in ''string1'' are compressed as described for the '''-s''' option (see below).
| | \NNN character with octal value NNN (1 to 3 octal digits) |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">tr [-Ccu] -ds ''string1'' ''string2''</div>
| | \\ backslash |
| | \a audible BEL |
| | \b backspace |
| | \f form feed |
| | \n new line |
| | \r return |
| | \t horizontal tab |
| | \v vertical tab |
|
| |
|
| In the fourth form, the characters in ''string1'' are deleted from the input, and the characters in ''string2'' are compressed as described for the '''-s''' option.
| | Along with [https://www.linuxnix.com/sedsteam-editor-explained-detail-linuxunix/ the Linux sed command], the tr command stands for translate is used to provide a level of swapping or translation, suppression or deletion of files. The tr command just translates one character to another character. In this article, we’ll share a couple of examples demonstrating some exciting things that we can do with the tr command. |
|
| |
|
| === {{anchor|RefHeadingToc7051523260012}} Options ===
| | tr OPTION ZEICHENFOLGE1 ZEICHENFOLGE2 |
| | tr [option] stringValue1 [stringValue2] |
|
| |
|
| | option and stringValue2 are optional for tr command. You can use -c, -s and -d option with tr command to do different types of tasks. |
| | tr [OPTION] [SET1] [SET2] |
|
| |
|
| {| style="border-spacing:0;margin:auto;width:17.501cm;"
| | SET1 denotes what we wish to translate in the input file, and SET2 means what we want to convert SET1 as the output of the translation. So the sets can be a single character or multiple characters. |
| |- style="border:none;padding:0.049cm;"
| |
| || '''-C'''
| |
| || Complement the set of characters in ''string1'', that is "'''-C ab'''" includes every character except for ''''a'''' and ''''b''''.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''-c'''
| |
| || Same as '''-C''' but complement the set of values in ''string1''.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''-d'''
| |
| || Delete characters in ''string1'' from the input.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''-s'''
| |
| || Squeeze multiple occurrences of the characters listed in the last operand (either ''string1'' or ''string2'') in the input into a single instance of the character. This occurs after all deletion and translation is completed.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''-u'''
| |
| || Guarantee that any output is unbuffered.
| |
|
| |
|
| | Example1: Suppose you just want to replace a in "sahil suri" with b we can use tr sets. We use [https://www.linuxnix.com/9-linux-echo-command-examples/ echo command] to send "sahil suri" to tr command. The tr command by default is not able to read data stream. We use [https://www.linuxnix.com/linuxunix-redirection-operatorsfile-descriptors-explained-examples/ Linux inbuilt redirection operators] to feed data to tr command. |
|
| |
|
| |- | | echo "sahil suri" | tr 'a' 'b' |
| |}
| | sbhil suri |
| === {{anchor|RefHeadingToc7071523260012}} How Characters Are Specified ===
| |
|
| |
|
| When specifying the characters to translate with '''tr''', the following conventions are used to represent sets (or "classes") of characters.
| | Example2: Suppose if you want to replace multiple characters one after the other then we can use below-set examples. Suppose you want to replace a with b, r with x and i with z, below is the case you are looking at. |
|
| |
|
| Any character not described by one of the following conventions represents itself.
| | echo "sahil suri" | tr 'ari' 'bxz' |
| | sbhzl suxz |
|
| |
|
| | Note: Make sure that first set and second set have the same number of characters. For example, i is just replaced with z as we don’t have the third character on the list below. |
|
| |
|
| {| style="border-spacing:0;margin:auto;width:17.501cm;"
| | echo "sahil suri" | tr 'ari' 'bz' |
| |- style="border:none;padding:0.049cm;" | | sbhzl suzz |
| || '''\'''''octal''
| |
| || A backslash followed by 1, 2 or 3 [https://www.computerhope.com/jargon/o/octal.htm octal] digits represents a character with that encoded value. To follow an octal sequence with a digit as a character, pad the octal sequence on the left with zeroes.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\'''''character''
| |
| || A backslash followed by certain special characters maps to special values:
| |
|
| |
|
| | Similarly, we can use sets to convert multiple letters. Some of the sets tr supports are as below. |
|
| |
|
| {| style="border-spacing:0;margin:auto;width:15.797cm;"
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\a'''
| |
| || The "alert" character, which issues a notification or alert to the terminal.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\b'''
| |
| || Backspace.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\f'''
| |
| || [https://www.computerhope.com/jargon/f/formfeed.htm Form feed].
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\n'''
| |
| || [https://www.computerhope.com/jargon/n/newline.htm Newline].
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\r'''
| |
| || [https://www.computerhope.com/jargon/c/cr.htm Carriage return].
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\t'''
| |
| || [https://www.computerhope.com/jargon/t/tab.htm Tab].
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''\v'''
| |
| || Vertical tab.
| |
| |-
| |
| |}
| |
| A backslash followed by any other character maps to that character.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || ''c'''''-'''''c''
| |
| || Character [https://www.computerhope.com/jargon/r/range.htm range]. For non-octal range endpoints represents the range of characters between the range endpoints, inclusive and in ascending order, as defined by the collation sequence. If either or both of the range endpoints are octal sequences, it represents the range of specific coded values between the range endpoints, inclusive.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''[:'''''class''''':]'''
| |
| || Represents all characters belonging to the defined character class. Class names are:
| |
|
| |
|
|
| |
|
| {| style="border-spacing:0;width:7.137cm;"
| | === Optionen === |
| |- style="border:none;padding:0.049cm;"
| | {| class="wikitable sortable" |
| || '''alnum'''
| | || Option |
| || [https://www.computerhope.com/jargon/a/alphanum.htm Alphanumeric] characters.
| | || Beschreibung |
| |- style="border:none;padding:0.049cm;"
| | |- |
| || '''alpha'''
| | || <tt>-c</tt>, <tt>-C</tt> oder <tt>--complement</tt> |
| || Alphabetic characters.
| | || Komplement der angegebenen Zeichenfolge |
| |- style="border:none;padding:0.049cm;"
| | |- |
| || '''blank'''
| | || <tt>-d</tt> oder <tt>--delete</tt> |
| || [https://www.computerhope.com/jargon/w/whitspac.htm White space] characters.
| | || Löschen (nicht Ersetzen) von Zeichen |
| |- style="border:none;padding:0.049cm;"
| |
| || '''cntrl'''
| |
| || Control characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''digit'''
| |
| || Numeric characters.
| |
| |- style="border:none;padding:0.049cm;" | |
| || '''graph''' | |
| || Graphic characters. | |
| |- style="border:none;padding:0.049cm;" | |
| || '''ideogram'''
| |
| || Ideographic characters. | |
| |- style="border:none;padding:0.049cm;"
| |
| || '''lower'''
| |
| || [https://www.computerhope.com/jargon/l/lowercas.htm Lowercase] alphabetic characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''phonogram'''
| |
| || Phonographic characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''print''' | |
| || Printable characters.
| |
| |- style="border:none;padding:0.049cm;" | |
| || '''punct'''
| |
| || Punctuation characters. | |
| |- style="border:none;padding:0.049cm;"
| |
| || '''rune'''
| |
| || Valid characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''space'''
| |
| || Space characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''special'''
| |
| || Special characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''upper'''
| |
| || [https://www.computerhope.com/jargon/u/uppercase.htm Uppercase] alphabetic characters.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''xdigit''' | |
| || [https://www.computerhope.com/jargon/h/hex.htm Hexadecimal] characters.
| |
| |- | | |- |
| | || <tt>-s</tt> oder <tt>--squeeze-repeats</tt> |
| | || Mehrere identische aufeinanderfolgende Zeichen durch ein einzelnes ersetzen |
| | |- |
| | || <tt>-t</tt> oder <tt>--truncate-set1</tt> |
| | || Beschneide zunächst den ersten Datensatz auf die Länge des zweiten Datensatzes |
| |} | | |} |
| When "'''[:lower:]'''" appears in ''string1'' and "'''[:upper:]'''" appears in the same relative position in ''string2'', it represents the characters pairs from the toupper mapping in the '''LC_CTYPE''' category of the current locale. When "'''[:upper:]'''" appears in ''string1'' and "'''[:lower:]'''" appears in the same relative position in ''string2'', it represents the characters pairs from the '''tolower''' mapping in the '''LC_CTYPE''' category of the current locale.With the exception of case conversion, characters in the classes are in unspecified order.For specific information as to which [https://www.computerhope.com/jargon/a/ascii.htm ASCII] characters are included in these classes, see '''ctype''' and related manual pages."'''[=equiv=]'''" Represents all characters belonging to the same equivalence class as '''equiv''', ordered by their encoded values.
| |
| |- style="border:none;padding:0.049cm;"
| |
| || '''['''''<nowiki>#</nowiki>'''''<nowiki>*</nowiki>'''''n''''']'''
| |
| || Represents ''n'' repeated occurrences of the character represented by ''<nowiki>#</nowiki>''. This expression is only valid when it occurs in ''string2''. If ''n'' is omitted, or is zero, it is be interpreted as large enough to extend ''string2'' sequence to the length of ''string1''. If ''n'' has a leading zero, it is interpreted as an octal value, otherwise, it is interpreted as a decimal value.
| |
|
| |
|
| |
|
| | === Befehlssequenzen === |
| | {| class="wikitable sortable" |
| | |- |
| | || Option |
| | || Beschreibung |
| | |- |
| | || <tt>\\</tt> |
| | || Backslash |
| | |- |
| | || <tt>\b</tt> |
| | || Rücktaste |
| | |- |
| | || <tt>\n</tt> |
| | || Zeilenumbruch |
| | |- |
| | || <tt>\t</tt> |
| | || Horizontaler Tab |
| | |- |
| | || <tt>ZEICHEN1-ZEICHEN 2</tt> |
| | || Alle Zeichen von ZEICHEN 1 bis ZEICHEN2 |
| | |- |
| | || <tt>[:alpha:]</tt> |
| | || Alle Buchstaben |
| | |- |
| | || <tt>[:blank:]</tt> |
| | || Alle horizontalen Leerzeichen |
| | |- |
| | || <tt>[:digit:]</tt> |
| | || Alle Zahlen |
| | |- |
| | || <tt>[:lower:]</tt> |
| | || Alle Kleinbuchstuben |
| | |- |
| | || <tt>[:upper:]</tt> |
| | || Alle Großbuchstaben |
| |- | | |- |
| |} | | |} |
| === {{anchor|RefHeadingToc7091523260012}} Environment ===
| |
|
| |
| The '''LANG''', '''LC_ALL''', '''LC_CTYPE''' and '''LC_COLLATE''' [https://www.computerhope.com/jargon/e/envivari.htm environment variables] affect the execution of '''tr'''.
| |
|
| |
| === {{anchor|RefHeadingToc7111523260012}} Exit Status ===
| |
|
| |
| '''tr''' returns an exit status of '''0''' if it operated successfully, and a value greater than zero if an error occurred.
| |
|
| |
| === {{anchor|RefHeadingToc7131523260012}} Examples ===
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">tr -cs "[:alpha:]" "\n" < file1</div>
| |
|
| |
| Create a list of the words in '''file1''', one per line, where a word is taken to be a maximal string of letters.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">tr "[:lower:]" "[:upper:]" < file1</div>
| |
|
| |
| Translate the contents of '''file1''' to uppercase.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">tr -cd "[:print:]" < file1</div>
| |
|
| |
| Remove all non-printable characters from '''file1'''.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">tr "[=e=]" "e"</div>
| |
|
| |
| Remove all "diacritical" marks from accented versions of the letter '''e'''.
| |
|
| |
| == {{anchor|RefHeadingToc7151523260012}} tr examples ==
| |
|
| |
| The tr command in UNIX is a command line utility for translating or deleting characters. It supports a range of transformations including uppercase to lowercase, squeezing repeating characters, deleting specific characters and basic find and replace. It can be used with UNIX pipes to support more complex translation. '''tr stands for translate.'''
| |
|
| |
| '''Syntax :'''
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ tr [OPTION] SET1 [SET2]'''</div>
| |
|
| |
| '''Options'''
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">-c : complements the set of characters in string.i.e., operations apply to characters not in the given set
| |
| -d : delete characters in the first set from the output.
| |
| -s : replaces repeated characters listed in the set1 with single occurrence
| |
| -t : truncates set1</div>
| |
|
| |
| === {{anchor|RefHeadingToc21721523260012}} Convert lower case to upper case ===
| |
|
| |
| To convert from lower case to upper case the predefined sets in tr can be used.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$cat greekfile'''</div>
| |
|
| |
| Output:
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">WELCOME TO
| |
| GeeksforGeeks</div>
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$cat greekfile | tr “[a-z]” “[A-Z]”'''</div>
| |
|
| |
| Output:
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">WELCOME TO
| |
| GEEKSFORGEEKS</div>
| |
|
| |
| or
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$cat geekfile | tr “[:lower:]” “[:upper:]”'''</div>
| |
|
| |
| Output:
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">WELCOME TO
| |
| GEEKSFORGEEKS</div>
| |
|
| |
| === {{anchor|RefHeadingToc21741523260012}} Translate white-space to tabs ===
| |
|
| |
| The following command will translate all the white-space to tabs
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "Welcome To GeeksforGeeks" | tr [:space:] '\t''''</div>
| |
|
| |
| Output:
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">Welcome To GeeksforGeeks </div>
| |
|
| |
| === {{anchor|RefHeadingToc21761523260012}} Translate braces into parenthesis ===
| |
|
| |
| You can also translate from and to a file. In this example we will translate braces in a file with parenthesis.
| |
|
| |
| '''$cat greekfile'''
| |
| {WELCOME TO}
| |
| GeeksforGeeks
| |
| '''$ tr '{}' '()' newfile.txt'''
| |
| (WELCOME TO)
| |
| GeeksforGeeks
| |
|
| |
| The above command will read each character from “geekfile.txt”, translate if it is a brace, and write the output in “newfile.txt”.
| |
|
| |
| === {{anchor|RefHeadingToc21781523260012}} Squeeze repetition ===
| |
|
| |
| To squeeze repeat occurrences of characters specified in a set use the -s option. This removes repeated instances of a character.OR we can say that,you can convert multiple continuous spaces with a single space
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "Welcome To GeeksforGeeks" | tr -s [:space:] ' ''''
| |
| Welcome To GeeksforGeeks</div>
| |
|
| |
| === {{anchor|RefHeadingToc21801523260012}} Delete specified characters ===
| |
|
| |
| To delete specific characters use the -d option.This option deletes characters in the first set specified.
| |
|
| |
| '''$ echo "Welcome To GeeksforGeeks" | tr -d 'w''''
| |
| elcome To GeeksforGeeks
| |
|
| |
| === {{anchor|RefHeadingToc21821523260012}} Remove all the digits from the string, use ===
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "my ID is 73535" | tr -d [:digit:]'''
| |
| my ID is</div>
| |
|
| |
| === {{anchor|RefHeadingToc21841523260012}} Complement the sets using -c option ===
| |
|
| |
| You can complement the SET1 using -c option. For example, to remove all characters except digits, you can use the following.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "my ID is 73535" | tr -cd [:digit:]'''
| |
| 73535</div>
| |
|
| |
| Or
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo “unix” | tr –c “u” “a”'''
| |
| Uaaa</div>
| |
|
| |
| === {{anchor|RefHeadingToc7171523260012}} tr Examples ===
| |
|
| |
| '''tr''' (short for '''translate''') is a useful command line utility that translates and/or deletes characters from stdin input, and writes to stdout. It is a useful program for manipulating text on the command line.
| |
|
| |
| The syntax for running '''tr command''' is as follows, where characters in '''SET1''' are translated to characters in '''SET2'''.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr flags [SET1] [SET2]</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39001523260012}} 1. A simple tr command ====
| |
|
| |
| Use case is to change all lower case letters in text to upper case and vice versa, as shown below.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ cat linux.txt
| |
| linux is my life
| |
| linux has changed my life
| |
| linux is best and everthing to me..:)'''</div>
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ cat domains.txt | tr [:lower:] [:upper:]
| |
| LINUX IS MY LIFE
| |
| LINUX HAS CHANGED MY LIFE
| |
| LINUX IS BEST AND EVERTHING TO ME..:)'''</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39021523260012}} Alternatively ====
| |
|
| |
| you can use the following command to change all lower case letters to upper case in a file as shown.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ cat linux.txt | tr [a-z] [A-Z]
| |
| LINUX IS MY LIFE
| |
| LINUX HAS CHANGED MY LIFE
| |
| LINUX IS BEST AND EVERTHING TO ME..:)'''</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39041523260012}} To save the results ====
| |
|
| |
| written to '''stdout''' in a file for later processing, use the shell’s output redirection feature <tt>(>)</tt> as shown.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ cat linux.txt | tr [a-z] [A-Z] >output.txt
| |
| $ cat output.txt'''
| |
| '''LINUX IS MY LIFE
| |
| LINUX HAS CHANGED MY LIFE
| |
| LINUX IS BEST AND EVERTHING TO ME..:)'''</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39061523260012}} In regards to the redirection ====
| |
|
| |
| you can send input to '''tr''' using the input redirection and redirect the output to a file using the same command, as shown.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ tr [a-z] [A-Z] < linux.txt >output.txt'''</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39081523260012}} Another useful feature ====
| |
|
| |
| you can use the <tt>-d</tt> flag to delete characters, for example to remove the spaces in the domain names using the following command.
| |
|
| |
| '''$ cat domains.txt
| |
| www. tecmint. Com
| |
| www. fossmint. Com
| |
| www. linuxsay. Com'''
| |
| '''$ cat domains.txt | tr -d '''''
| |
| [http://www.tecmint.com/ www.tecmint.com]
| |
| [http://www.fossmint.com/ www.fossmint.com]
| |
| www.linuxsay.com'''
| |
|
| |
| ==== {{anchor|RefHeadingToc39101523260012}} If there are repeated characters in a sequence ====
| |
|
| |
| (for instance double spaces) in the text you are processing, you can use the <tt>-s</tt> option to squeeze the characters leaving only one occurrence of it.
| |
|
| |
| '''$ cat domains.txt
| |
| www.tecmint.....com
| |
| [http://www.fossmint.com/ www.fossmint.com]
| |
| [http://www.linuxsay.com/ www.linuxsay.com]
| |
| '''$ cat domains.txt | tr -s '''''
| |
| [http://www.tecmint.com/ www.tecmint.com]
| |
| [http://www.fossmint.com/ www.fossmint.com]
| |
| www.linuxsay.com'''
| |
|
| |
| ==== {{anchor|RefHeadingToc39121523260012}} The -c option ====
| |
|
| |
| tells '''tr''' to use the complement in the given of '''SET'''. In this example, we want to delete all the letters and only leave the '''UID'''.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "My UID is $UID" | tr -cd "[:digit:]\n"'''
| |
| OR
| |
| '''$ echo "My UID is $UID" | tr -d "a-zA-Z"'''</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc39141523260012}} Here is an example of breaking a single line ====
| |
|
| |
| of words (sentence) into multiple lines, where each word appears in a separate line.
| |
|
| |
| '''$ echo "My UID is $UID"
| |
| My UID is 1000'''
| |
| '''$ echo "My UID is $UID" | tr " " "\n"
| |
| My
| |
| UID
| |
| is
| |
| 1000'''
| |
|
| |
| ==== {{anchor|RefHeadingToc39161523260012}} Related to the previous example ====
| |
|
| |
| you can also translate multiple lines of words into a single sentence as shown.
| |
|
| |
| '''$ cat uid.txt
| |
| My
| |
| UID
| |
| is
| |
| 1000'''
| |
| '''$ tr "\n" " " < uid.txt
| |
| My UID is 1000'''
| |
|
| |
| ==== {{anchor|RefHeadingToc39181523260012}} translate a single character ====
| |
|
| |
| for instance a space into a <tt>“ : ”</tt> character, as follows.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">'''$ echo "Tecmint.com =>Linux-HowTos,Guides,Tutorials" | tr " " ":"
| |
| Tecmint.com:=>Linux-HowTos,Guides,Tutorials'''</div>
| |
|
| |
| There are several sequence characters you can use with '''tr''', for more information, see the '''tr''' man page.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ man tr</div>
| |
|
| |
| That’s all! '''tr''' is a useful command for manipulating text on the command line. In this guide, we showed some useful '''tr command''' usage examples for Linux newbies. You can share your thoughts with us via the comment form below.
| |
|
| |
| == {{anchor|RefHeadingToc7211523260012}} TR Examples ==
| |
|
| |
| tr is an UNIX utility for translating, or deleting, or squeezing repeated characters. It will read from STDIN and write to STDOUT.
| |
|
| |
| tr stands for translate.
| |
|
| |
| === {{anchor|RefHeadingToc7231523260012}} Syntax ===
| |
|
| |
| The syntax of tr command is:
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr [OPTION] SET1 [SET2]</div>
| |
|
| |
| === {{anchor|RefHeadingToc7251523260012}} Translation ===
| |
|
| |
| If both the SET1 and SET2 are specified and ‘-d’ OPTION is not specified, then tr command will replace each characters in SET1 with each character in same position in SET2.
| |
|
| |
| === {{anchor|RefHeadingToc7271523260012}} Convert lower case to upper case ===
| |
|
| |
| The following tr command is used to convert the lower case to upper case
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr abcdefghijklmnopqrstuvwxyz ABCDEFGHIJKLMNOPQRSTUVWXYZ
| |
| thegeekstuff
| |
| THEGEEKSTUFF</div>
| |
|
| |
| The following command will also convert lower case to upper case
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr [:lower:] [:upper:]
| |
| thegeekstuff
| |
| THEGEEKSTUFF</div>
| |
|
| |
| You can also use ranges in tr. The following command uses ranges to convert lower to upper case.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr a-z A-Z
| |
|
| |
| thegeekstuff
| |
| THEGEEKSTUFF</div>
| |
|
| |
| === {{anchor|RefHeadingToc7291523260012}} Translate braces into parenthesis ===
| |
|
| |
| You can also translate from and to a file. In this example we will translate braces in a file with parenthesis.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr '{}' '()' < inputfile > outputfile</div>
| |
|
| |
| The above command will read each character from “inputfile”, translate if it is a brace, and write the output in “outputfile”.
| |
|
| |
| === {{anchor|RefHeadingToc7311523260012}} Translate white-space to tabs ===
| |
|
| |
| The following command will translate all the white-space to tabs
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "This is for testing" | tr [:space:] '\t'
| |
| This is for testing</div>
| |
|
| |
| === {{anchor|RefHeadingToc7331523260012}} Squeeze repetition of characters using -s ===
| |
|
| |
| In Example 3, we see how to translate space with tabs. But if there are two are more spaces present continuously, then the previous command will translate each spaces to a tab as follows.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "This is for testing" | tr [:space:] '\t'
| |
| This is for testing</div>
| |
|
| |
| We can use -s option to squeeze the repetition of characters.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "This is for testing" | tr -s [:space:] '\t'
| |
| This is for testing</div>
| |
|
| |
| Similarly you can convert multiple continuous spaces with a single space
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "This is for testing" | tr -s [:space:] ' '
| |
| This is for testing</div>
| |
|
| |
| ==== {{anchor|RefHeadingToc7351523260012}} Delete specified characters using -d option ====
| |
|
| |
| tr can also be used to remove particular characters using -d option.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "the geek stuff" | tr -d 't'
| |
| he geek suff</div>
| |
|
| |
| To remove all the digits from the string, use
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "my username is 432234" | tr -d [:digit:]
| |
| my username is</div>
| |
|
| |
| Also, if you like to delete lines from file, you can use [https://www.thegeekstuff.com/2009/09/unix-sed-tutorial-delete-file-lines-using-address-and-patterns/ sed d command].
| |
|
| |
| === {{anchor|RefHeadingToc7371523260012}} Complement the sets using -c option ===
| |
|
| |
| You can complement the SET1 using -c option. For example, to remove all characters except digits, you can use the following.
| |
|
| |
| <div style="margin-left:0cm;margin-right:0cm;">$ echo "my username is 432234" | tr -cd [:digit:]
| |
| 432234</div>
| |
|
| |
| === {{anchor|RefHeadingToc7391523260012}} Remove all non-printable character ===
| |
|
| |
|
| The following command can be used to remove all non-printable characters from a file.
| | Weitere Angaben sind der [https://wiki.ubuntuusers.de/man/ Manpage] zu entnehmen. Man beachte, dass die [https://wiki.ubuntuusers.de/Zsh/ Zsh] die eckigen Klammern beispielsweise in <tt>[:blank:]</tt> als Wildcard-Parameter interpretiert und sie daher nicht an <tt>tr</tt> weitergibt. Benutzer der Zsh sollten solche Argument daher in einfache oder doppelte Anführungszeichen einschließen. |
|
| |
|
| <div style="margin-left:0cm;margin-right:0cm;">$ tr -cd [:print:] < file.txt</div>
| | === Argumente === |
|
| |
|
| === {{anchor|RefHeadingToc7411523260012}} Join lines to one === | | === Umgebungsvariablen === |
| | === Exit-Status === |
|
| |
|
| The below command will translate all newlines into spaces and make the result as a single line.
| | == Siehe auch == |
| | | === Dokumentation === |
| <div style="margin-left:0cm;margin-right:0cm;">$ tr -s '\n' ' ' < file.txt</div>
| | ==== RFC ==== |
| | | ==== Man-Page ==== |
| == {{anchor|RefHeadingToc35251523260012}} Siehe auch == | | ==== Info-Pages ==== |
| | | === Links === |
| * [https://de.wikipedia.org/wiki/Sed_(Unix) Sed (Unix)]https://de.wikipedia.org/wiki/Sed_(Unix) | | ==== Projekt ==== |
| * [http://man.cat-v.org/unix_8th/1/tr tr(1)] - Unix achter Handbucheintrag. | | ==== Weblinks ==== |
| * [https://linux.die.net/man/1/tr [1]] [https://de.wikipedia.org/wiki/Manpage Manpage] | | * [https://de.wikipedia.org/wiki/Sed_(Unix) Sed (Unix)][https://de.wikipedia.org/wiki/Sed_(Unix) https://de.wikipedia.org/wiki/Sed_(Unix)] |
| * [http://www.examplenow.com/tr Beispiele aus examplenow.com] | | * [https://man.cat-v.org/unix_8th/1/tr tr(1)] - Unix achter Handbucheintrag. |
| * [http://www.gnu.org/software/coreutils/ GNU Core Utilities] 🇬🇧http://www.gnu.org/software/coreutils/ | | * [https://linux.die.net/man/1/tr [1]] [https://de.wikipedia.org/wiki/Manpage Manpage] |
| | * [https://www.examplenow.com/tr Beispiele aus examplenow.com] |
| | * [https://www.gnu.org/software/coreutils/ GNU Core Utilities] 🇬🇧[https://www.gnu.org/software/coreutils/ https://www.gnu.org/software/coreutils/] |
| * [https://en.wikipedia.org/wiki/Tr_(Unix) tr] | | * [https://en.wikipedia.org/wiki/Tr_(Unix) tr] |
| * [http://www.prontosystems.org/tux/tr tr: Translate Characters -> Syntax und Beispiele] 🇩🇪 – Blogartikel 5/2010 | | * [https://www.prontosystems.org/tux/tr tr: Translate Characters -> Syntax und Beispiele] 🇩🇪 - Blogartikel 5/2010 |
| * [http://www.easylinux.de/Artikel/ausgabe/2003/11/068-shell-tipps/ Shell-Tipps] 🇩🇪 – Artikel in EasyLinux 11/2003 | | * [https://www.easylinux.de/Artikel/ausgabe/2003/11/068-shell-tipps/ Shell-Tipps] 🇩🇪 - Artikel in EasyLinux 11/2003 |
| * [https://wiki.ubuntuusers.de/Shell/Befehlsübersicht/ Shell/Befehlsübersicht] Übersicht über verschiedene Shell-Befehle | | * [https://wiki.ubuntuusers.de/Shell/Befehlsübersicht/ Shell/Befehlsübersicht] Übersicht über verschiedene Shell-Befehle |
|
| |
|
| [[Category:Entwurf]] | | |
| | [[Kategorie:Linux/Befehl]] |
| | [[Kategorie:Coreutils]] |
| | {{DEFAULTSORT:tr}} |
tr - in Texte systematisch Zeichen durch andere Zeichen ersetzen
Beschreibung
Der Befehl tr (von translate = umwandeln oder transliterate = transliterieren) dient dazu, in Texten systematisch Zeichen durch andere Zeichen zu ersetzen. So ist es beispielweise möglich, alle Großbuchstaben einer Datei durch Kleinbuchstaben zu ersetzen oder mehrere aufeinander folgende Leerzeichen durch ein einziges zu ersetzen. Für komplexere Ersetzungen, beispielsweise für ganze Wörter, empfiehlt sich das wesentlich mächtigere sed.
tr ist ein Unix-Kommando, dessen Name eine Abkürzung für translate (deutsch: übersetzen) ist, das bestimmte Zeichen aus einem Datenstrom ersetzt oder entfernt.
Das Werkzeug liest den Datenstrom der Standardeingabe, schreibt auf die Standardausgabe und benötigt je nach Modus ein (Löschen und Komprimieren) oder zwei (Ersetzen) Argumente.
Sollen Zeichen ersetzt werden, werden zwei Argumente benötigt, zuerst die zu ersetzenden Zeichen, im zweiten die neuen.
Abhängig von der Art der Arbeit, die Sie auf der Kommandozeile unter Linux erledigen, können Sie ein Dienstprogramm wünschen, das als Schweizer Taschenmesser für die schnelle Textbearbeitung fungieren kann. Gerne gibt es ein Tool namens tr, das sich für diese Rolle qualifiziert. In diesem Tutorial werden wir die Grundlagen von tr anhand einiger leicht verständlicher Beispiele diskutieren.
Aber bevor wir das tun, ist es erwähnenswert, dass alle Beispiele in diesem Artikel auf einem Ubuntu 18.04 LTS-Rechner getestet wurden.
tr is a very useful UNIX command. It is used to transform string or delete characters from the string. Various type of transformation can be done by using this command, such as searching and replacing text, transforming string from uppercase to lowercase or vice versa, removing repeated characters from the string und weitere The command can be used for some complicated transformation also. The different uses of tr command are shown in this tutorial.
So erklärt es die Man Page des Tools:
Translate, squeeze, and/or delete characters from standard input, writing to standard output.
Anwendungen
Einfaches Beispiel
Ersetzen eines Buchstabens durch einen anderen
echo Maus | tr M H
Haus
Mit folgendem Befehl werden Groß- in Kleinbuchstaben umgewandelt:
echo 'FLÜSTERN' | tr A-ZÄÖÜ a-zäöü
oder auch
echo 'FLÜSTERN' | tr [:upper:]ÄÖÜ [:lower:]äöü
ergibt
flüstern
… und umgekehrt:
echo 'schreien' | tr a-zäöü A-ZÄÖÜ
SCHREIEN
Bestimmte Zeichen, hier alle Zahlen in der Datei datei.txt, lassen sich mit der Option -d löschen:
tr -d '0-9' < datei.txt
Soll aus mehrere aufeinanderfolgenden Leerzeichen ein einzelnes gemacht werden, kann man die Option -s verwenden:
echo 'd b' |tr -s ' '
d b
Um alle Zeichen zu entfernen, die nicht einer bestimmten Zeichengruppe angehören, kann die Option -c benutzt werden. Im folgenden Beispiel werden alle Zeichen entfernt, die keine Buchstaben sind:
echo 'Die drei ??? treffen die 12 Geschworenen!' | tr -cd '[:alpha:]' > datei
cat datei
DiedreitreffendieGeschworenen
Mit Hilfe von tr lässt sich ein Text auch sehr leicht Rot13 chiffrieren und dechiffieren:
echo 'Morgen bringen wir Cäsar um' | tr [a-zA-Z] [n-za-mN-ZA-M]
Zbetra oevatra jve Päfne hz
Und wieder zurück:
echo 'Zbetra oevatra jve Päfne hz' | tr [a-zA-Z] [n-za-mN-ZA-M]
Morgen bringen wir Cäsar um
Um in einer Datei Zeichen zu ändern und das Ergebnis in eine zweite Datei zu schreiben, können Umleitungen eingesetzt werden. Mit dem folgenden Befehl werden alle Vorkommen des Buchstabens a in datei1 in den Buchstaben b umgewandelt und das Ergebnis in datei2 geschrieben:
tr a b < datei1 > datei2
Der folgende Befehl entfernt alle Wagenrückläufe ("Carriage Return", mehr unter Zeichensatz-Konverter) und konvertiert so eine Datei datei1 vom Windows- in das Unixformat:
tr -d '\r' < datei1 > ausgabedatei
Alle mehrfach aufeinander folgenden Zeilenumbrüche ("new line") in datei1 werden in jeweils einen umgewandelt:
tr -s '\n' < datei1 > ausgabedatei
Der folgende Befehl führt dazu, dass alle kommaseparierten Elemente einer CSV-Datei datei.csv jeweils in einer neuen Zeile erscheinen:
tr ',' '\n' < datei.csv
Beispiel:
$ echo Meyer | tr y i
Meier
Es sind mehrfache Ersetzungen einzelner Zeichen auf einmal möglich. Z.B. ersetzt
tr 'abcd' 'jkmn'
alle vorkommenden a durch j, b durch k und weitere
Im Alphabet aufeinanderfolgende Zeichen lassen sich dabei mit einem Bindestrich angeben:
tr 'a-d' 'jkmn'
Mit dem Operator s werden alle hintereinander folgenden identischen Zeichen durch ein einzelnes ersetzt. Beispiel:
echo muuuuh | tr -s u
muh
Der Operand d löscht alle im ersten Argument angegebenen Zeichen
tr -d '\r'
wobei \r für ein Carriage Return (Bytewert 13) steht. Mit diesem Befehl wird dieses unter Unix nicht verwendete Umbruchzeichen ersatzlos entfernt.
Ist ein c angegeben, so gilt die Umkehrung, also hier
tr -cd '[:alnum:]'
wobei der Ausdruck [:alnum:] für alle alphanumerischen Zeichen steht. Somit werden alle nicht alphanumerischen Zeichen entfernt.
Change case
You can change the case of the string very easily by using tr command. To define uppercase, you can use [:upper:] or [A-Z] and to define lowercase you can define [:lower:] or [a-z].
tr command can be used in the following way to convert any string from uppercase to lowercase.
tr [:upper:] [:lower:]
You can use tr command in the following way also to convert any string from lowercase to uppercase.
tr a-z A-Z
Run the following command to convert every small letter of the string,’linuxhint’ into the capital letter.
$ echo linuxhint | tr [:lower:] [:upper:]
You can apply tr command for converting the content of any text file from upper to lower or lower to upper. Suppose, you have text file named, items.txt with the following contents.
- Monitor
- Keyboard
- Mouse
- Scanner
- HDD
Run the following commands from the terminal to display the content of items.txt and the output of tr command after converting the content of that file from lower to upper case. The following tr command will not modify the original content of the file.
$ cat items.txt
$ tr a-z A-Z < items.txt
You can run the following command to store the output of the tr command into another file named ‘output.txt’.
$ tr [:upper:] [:lower:] < items.txt > output.txt
$ cat output.txt
Translate character
tr command can be used to search and replace any particular character from any text. The following command is used to convert each space of the text, "Welcome to Linuxhint" by newline (\n).
$ echo "Welcome To Linuxhint" | tr [:space:] '\n'
-c option
tr command can be used with -c option to replace those characters with the second character that don’t match with the first character value. In the following example, tr command is used to search those characters in the string ‘bash’ that don’t match with the character ‘b’ and replace them by ‘a’. The output is ‘baaaa’. Four characters are converted here. These are ,’a’,’s’,’h’ and ‘\n’.
$ echo "bash" | tr -c 'b' 'a'
-s option
tr command uses -s option for search and replace any string from a text. In the following example, space (‘ ‘) is replaced by tab (‘\t’).
$ echo "BASH Programming" | tr -s ' ' '\t'
You can use both -c and -s options together with tr command. In the following example, the range of small letter is used as the first string value. For -c option, tr command will search and replace each capital letter by newline (‘\n’) of the file, items.txt and store the output of the command in the file, output.txt.
$ cat items.txt
$ tr -cs [a-z] "\n" < items.txt > output.txt
$ cat output.txt
-d option
-d option used with tr command to search and delete any character or string from a text. In the following example, tr command will search ‘P’, ‘y’ and ‘t’ in the string "Python is a Programming language" and delete those characters.
$ echo "Python is a Programming language" | tr -d 'Pyt'
-c option can be used with -d option in the tr command to complement the search like precious -cs command. In the following example, tr command with -cd will search all non-digit characters from the string, "Phone No: 985634854" and delete them.
$ echo "Phone No: 985634854" | tr -cd '0-9'
In a similar way, you can run use -cd option in tr command like the following command to remove the non-printable characters from a file. No nonprintable character exists in items.txt. So the output will be the same as the file content.
$ tr -cd "[:print:]" < items.txt
lower case to upper case
Suppose you want to convert the sentence "linux tutorial on howtoforge" to uppercase, then here's how you can do this using tr.
echo 'linux tutorial on howtoforge' | tr "[:lower:]" "[:upper:]"
The above command produced the following output on my system:
LINUX TUTORIAL ON HOWTOFORGE
Suppose you have a line like: "HowtoForge is an extremely good resource for Linux tutorials". And the requirement is to strip extra spaces from this line.
Here's how you can use tr to do this:
$ echo 'HowtoForge is an extremely good resource for Linux tutorials' | tr -s '[:space:]'
HowtoForge is an extremely good resource for Linux tutorials
Delete text
Suppose you want to delete the hyphens from the following line: "HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials." Then here's how you can do this using tr.
echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr -d '-'
Following is the output it produces:
HowtoForge is an extremely good resource for Linux tutorials
Replace characters
In the previous section, suppose the requirement was to replace hyphens with, let's say, dots. Then here's how you can do that using tr.
echo 'HowtoForge -- is -- an -- extremely -- good -- resource -- for -- Linux -- tutorials' | tr '-' '.'
Following is the output it produced:
HowtoForge .. is .. an .. extremely .. good .. resource .. for .. Linux .. tutorials
POSIX Character set
[:digit:] Only the digits 0 to 9
[:alnum:] Any alphanumeric character
[:alpha:] Any alpha character A to Z or a to z.
[:blank:] Space and TAB characters only.
[:xdigit:] Hexadecimal notation 0-9, A-F, a-f.
[:punct:] Punctuation symbols . , " ‘ ? ! ; : # $ % & ( ) * + - / < > = @ [ ] \ ^ _ { } | ~
[:print:] Any printable character.
[:space:] Any whitespace characters (space, tab, NL, FF, VT, CR). Many system abbreviates as \s.
[:graph:] Exclude whitespace (SPACE, TAB). Many system abbreviate as \W.
[:upper:] Any alpha character A to Z.
[:lower:] Any alpha character a to z.
[:cntrl:] Control Characters NL CR LF TAB VT FF NUL SOH STX EXT EOT ENQ ACK SO SI DLE DC1 DC2 DC3 DC4 NAK SYN ETB CAN EM SUB ESC IS1 IS2 IS3 IS4 DEL.
Character sets
- a-z To represent complete lower case alphabets
- A-Z to represent upper case alphabets
- 0-9 To describe the set of numbers.
lower to upper case.
echo "sahil suri" | tr 'a-z' 'A-Z'
SAHIL SURI
The tr command mentioned above implies to translate all alphabets in lowercase denoted by ‘a-z’ into alphabets in upper case denoted by ‘A-Z’
Convert all characters in input from upper to lower case
echo "SAHIL SURI" | tr 'A-Z' 'a-z'
sahil suri
Translate only particular characters from lower to upper case
echo "sahil suri" | tr 'shlr' 'SHLR'
SaHiL SuRi
In the previous two examples, we gave ranges, but we can use distinct characters as well as shown in the above example.
Use multiple ranges
echo "sahil suri" | tr 'a-dr-z' 'A-DR-Z'
SAhil SURi
translate individual characters as well
Translate braces into parenthesis
echo "{ Hello World }" > infile
tr '{}' '()' < infile > outfile
cat outfile
( Hello World )
Translate spaces to new lines.
We use infile as our test file. Use cat command to display the content of the file.
cat infile
solaris linux aix
cat infile | tr " " "\n"
solaris
linux
aix
cat infile | tr "[:space:] " "\n"
solaris
linux
aix
While using translate, you may use " " or [:space:] to represent white space. I find the first option easier to type.
Replace white space
cat infile | tr " " ":"
solaris:linux:aix
cat infile | tr " " "|"
solaris|linux|aix
Replace multiple occurrences
... with a single appearance of the character.
In below example, we replaced numerous spaces with separate space.
cat infile
solaris linux aix
tr -s " " < infile
solaris linux aix
In the above case, we used the tr command with -s option to indicate a squeeze operation.This replaces multiple occurrences of a character with a single appearance of the same character.
… with a different character
cat infile
solaris linux aix
tr -s " " ";" < infile
solaris;linux;aix
The above tr command squeezes multiple occurrences of white space into one semicolon character.
Delete all occurances of a character.
To delete occurrences of a character we use the -d option with the tr command followed by the character to be removed.
echo "linuxunix" | tr -d 'u'
linxnix
The above command removes all occurrences of the character u from the input string.
Remove all digits from the input.
echo "james bond 007" | tr -d '0-9'
james bond
Remove all alphabets from the input.
echo "james bond 007" | tr -d 'a-zA-Z'
007
Remove characters except the given
We used -d option to delete characters we mentioned from the input. We may use the -c option with the -d option to delete all characters except those that we mention.
echo "solaris linux hp-ux" | tr -cd 'slh'
slslh
The above tr command removed all characters including the new line leaving behind the characters s,l and h which we mentioned to be removed. Using the -c option is also sometimes referred to as complimenting the set.
Remove all non-alphanumeric and space
echo "solaris | linux 007 ; hp-ux :::: aix" | tr -cd "[:alpha:][:space:][:digit:]"
solaris linux 007 hpux aix
This example could prove to be especially useful when dealing with a file having a lot of junk characters.
Translate non-alphanumeric characters into a single newline character
echo "james bond 007" | tr -cs 'a-zA-Z0-9' '\n'
james
bond
007
Join lines in a file into a single
cat infile
solaris
linux
aix
tr -s '\n' ' ' < infile
solaris linux aix [root@linuxnix ~]#
The above tr command squeezes the new line character into a single space character.This option can be useful when attempting to consolidate scattered text in a file.
This concludes our exploration of the tr command. Please consider reading our articles about sed which is another utility that provides most of the translation features we discussed in the above examples and a lot more.
Problembehebung
Aufruf
Und folgendes ist seine Syntax:
tr [OPTION]... SET1 [SET2]
hier ist, was SET bedeutet:
SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are: \NNN character with octal value NNN (1 to 3 octal digits)
\\ backslash
\a audible BEL
\b backspace
\f form feed
\n new line
\r return
\t horizontal tab
\v vertical tab
Depending on the kind of work you do on the command line in Linux, you may want a utility that can act as a Swiss army knife of quick text editing. Gladly, there exists a tool dubbed tr, which qualifies for this role. In this tutorial, we will discuss the basics of tr using some easy to understand examples.
Here's how the tool's man page explains it:
Translate, squeeze, and/or delete characters from standard input, writing to standard output.
And following is its syntax:
tr [OPTION]... SET1 [SET2]
here's what SET means:
SETs are specified as strings of characters. Most represent themselves. Interpreted sequences are:
\NNN character with octal value NNN (1 to 3 octal digits)
\\ backslash
\a audible BEL
\b backspace
\f form feed
\n new line
\r return
\t horizontal tab
\v vertical tab
Along with the Linux sed command, the tr command stands for translate is used to provide a level of swapping or translation, suppression or deletion of files. The tr command just translates one character to another character. In this article, we’ll share a couple of examples demonstrating some exciting things that we can do with the tr command.
tr OPTION ZEICHENFOLGE1 ZEICHENFOLGE2
tr [option] stringValue1 [stringValue2]
option and stringValue2 are optional for tr command. You can use -c, -s and -d option with tr command to do different types of tasks.
tr [OPTION] [SET1] [SET2]
SET1 denotes what we wish to translate in the input file, and SET2 means what we want to convert SET1 as the output of the translation. So the sets can be a single character or multiple characters.
Example1: Suppose you just want to replace a in "sahil suri" with b we can use tr sets. We use echo command to send "sahil suri" to tr command. The tr command by default is not able to read data stream. We use Linux inbuilt redirection operators to feed data to tr command.
echo "sahil suri" | tr 'a' 'b'
sbhil suri
Example2: Suppose if you want to replace multiple characters one after the other then we can use below-set examples. Suppose you want to replace a with b, r with x and i with z, below is the case you are looking at.
echo "sahil suri" | tr 'ari' 'bxz'
sbhzl suxz
Note: Make sure that first set and second set have the same number of characters. For example, i is just replaced with z as we don’t have the third character on the list below.
echo "sahil suri" | tr 'ari' 'bz'
sbhzl suzz
Similarly, we can use sets to convert multiple letters. Some of the sets tr supports are as below.
Optionen
| Option
|
Beschreibung
|
| -c, -C oder --complement
|
Komplement der angegebenen Zeichenfolge
|
| -d oder --delete
|
Löschen (nicht Ersetzen) von Zeichen
|
| -s oder --squeeze-repeats
|
Mehrere identische aufeinanderfolgende Zeichen durch ein einzelnes ersetzen
|
| -t oder --truncate-set1
|
Beschneide zunächst den ersten Datensatz auf die Länge des zweiten Datensatzes
|
Befehlssequenzen
| Option
|
Beschreibung
|
| \\
|
Backslash
|
| \b
|
Rücktaste
|
| \n
|
Zeilenumbruch
|
| \t
|
Horizontaler Tab
|
| ZEICHEN1-ZEICHEN 2
|
Alle Zeichen von ZEICHEN 1 bis ZEICHEN2
|
| [:alpha:]
|
Alle Buchstaben
|
| [:blank:]
|
Alle horizontalen Leerzeichen
|
| [:digit:]
|
Alle Zahlen
|
| [:lower:]
|
Alle Kleinbuchstuben
|
| [:upper:]
|
Alle Großbuchstaben
|
Weitere Angaben sind der Manpage zu entnehmen. Man beachte, dass die Zsh die eckigen Klammern beispielsweise in [:blank:] als Wildcard-Parameter interpretiert und sie daher nicht an tr weitergibt. Benutzer der Zsh sollten solche Argument daher in einfache oder doppelte Anführungszeichen einschließen.
Argumente
Umgebungsvariablen
Exit-Status
Siehe auch
Dokumentation
RFC
Man-Page
Info-Pages
Links
Projekt
Weblinks