it-swarm.com.de

Das Ersetzen von [0-9] durch [A-J] funktioniert nicht mit sed

Ich arbeite an einem Befehl, der alle Ziffern 0-9 durch die entsprechenden Buchstaben in sed ersetzt. Ich weiß, dass ich etwas falsch mache, aber sed interpretiert den Ersatz-Regex nicht als irgendetwas anderes als ein String-Literal.

Der Befehl, den ich benutze, ist sed -r 's/[0-9]/[A-J]/g' log > ~/output.txt

Es scheint mir ziemlich einfach zu sein, aber ich habe ungefähr eine Stunde daran festgehalten. Die Ausgabe, die ich erhalte, ersetzt nur 0-9 durch die Zeichenfolge "[A-J]".

11
Matthew Snell

Bei der Substitution ist nur die Übereinstimmung (linke Seite) ein regulärer Ausdruck. Das Ersetzen ist mehr oder weniger nur eine wörtliche Zeichenfolge (mit einigen Backslash-Erweiterungen) - es ist kein regulärer Ausdruck .

Sie möchten Transliteration, nicht Substitution, also ersetzen Sie s durch y:

echo 34031445 | sed 'y/0123456789/ABCDEFGHIJ/'

sed kann keine Bereiche in y verwenden, aber Perl kann:

echo 34031445 | Perl -pe 'y/0-9/A-J/'

Oder benutze einfach tr:

echo 34031445 | tr 0-9 A-J
38
choroba