Hier ist eine awk + for-Loop-Version:
for filename in *; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
Und hier ist es in Aktion
$ ls
$ echo "TEST" | tee {foo,bar}_{yolo,swag}_{whatever,else}.txt
TEST
$ ls
bar_swag_else.txt bar_yolo_else.txt foo_swag_else.txt foo_yolo_else.txt
bar_swag_whatever.txt bar_yolo_whatever.txt foo_swag_whatever.txt foo_yolo_whatever.txt
$ for filename in *; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
$ ls
bar swag else.txt bar yolo else.txt foo swag else.txt foo yolo else.txt
bar swag whatever.txt bar yolo whatever.txt foo swag whatever.txt foo yolo whatever.txt
Um Zeilenumbrüche und eine mögliche Umbenennung von Verzeichnissen zu berücksichtigen, finden Sie hier das typische IFS + find + read + while-Schleifenkonstrukt. Führen Sie nach dem Vorschlagen des Vorschlags zuerst die Version mit aus find . -type d -print0
. Wenn Sie zuerst mit dem Umbenennen von Dateien beginnen und ein Unterverzeichnis einen Unterstrich enthält, wird der Dateiname nicht geändert. Kurz gesagt, kümmern Sie sich zuerst um Verzeichnisse und Unterverzeichnisse und dann um die Dateien
$ ls
file_bar_swag.txt file_bar_yolo.txt file_test_swag.txt file_test_yolo.txt foo_bar_swag.txt foo_bar_yolo.txt foo_test_swag.txt foo_test_yolo.txt tester_dir
$ ls tester_dir/
ber_sweg_elze.txt ber_sweg_whut.txt ber_yelo_elze.txt ber_yelo_whut.txt fee_sweg_elze.txt fee_sweg_whut.txt fee_yelo_elze.txt fee_yelo_whut.txt
$ find . -type d -print0 | while IFS="" read -r -d "" filename ; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
mv: ‘.’ and ‘./.’ are the same file
$ ls
file_bar_swag.txt file_bar_yolo.txt file_test_swag.txt file_test_yolo.txt foo_bar_swag.txt foo_bar_yolo.txt foo_test_swag.txt foo_test_yolo.txt tester dir
$ find . -type f -print0 | while IFS="" read -r -d "" filename ; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
mv: ‘./.yolo’ and ‘./.yolo’ are the same file
$ ls
file bar swag.txt file bar yolo.txt file test swag.txt file test yolo.txt foo bar swag.txt foo bar yolo.txt foo test swag.txt foo test yolo.txt tester dir
Wie Sie sehen, gibt es ein kleines Problem: Da der Befehl find auch das aktuelle Verzeichnis auflistet (symbolisiert mit einem.), Erstellt der Befehl ein Nebenprodukt - eine Datei mit einem führenden Punkt.
Das Hinzufügen, ! -path .
wenn Sie mit Verzeichnissen arbeiten, löst das Problem
$ find . ! -path . -type d -print0 | while IFS="" read -r -d "" filename ; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
$ find . -type f -print0 | while IFS="" read -r -d "" filename ; do NEWNAME=$(echo "$filename" | awk '{gsub("_"," "); print}'); mv "$filename" "$NEWNAME";done
$ ls
file bar swag.txt file bar yolo.txt file baz swag.txt file baz yolo.txt foo bar swag.txt foo bar yolo.txt foo baz swag.txt foo baz yolo.txt tester dir
$ ls "tester dir"
file bar.txt file baz.txt foo bar.txt foo baz.txt
$ ls -a
. .. file bar swag.txt file bar yolo.txt file baz swag.txt file baz yolo.txt foo bar swag.txt foo bar yolo.txt foo baz swag.txt foo baz yolo.txt tester dir