PROBLEM: Kennzeichnen Sie eine Datei oben in der Datei mit dem Basisnamen des übergeordneten Verzeichnisses.
Dh für
/mnt/Vancouver/Programming/file1
Markieren Sie die Oberseite file1
mit Programming
.
LÖSUNG 1 - Nicht leere Dateien:
bn=${PWD##*/} ## bn: basename
sed -i '1s/^/'"$bn"'\n/' <file>
1s
Platziert den Text in Zeile 1 der Datei.
LÖSUNG 2 - leere oder nicht leere Dateien:
Der sed
obige Befehl schlägt bei leeren Dateien fehl. Hier ist eine Lösung, die auf /superuser/246837/how-do-i-add-text-to-the-beginning-of-a-file-in-bash/246841#246841 basiert
printf "${PWD##*/}\n" | cat - <file> > temp && mv -f temp <file>
Beachten Sie, dass der -
Befehl in cat erforderlich ist (liest die Standardeingabe: siehe man cat
für weitere Informationen). Hier, glaube ich, ist es notwendig, die Ausgabe der printf-Anweisung (nach STDIN) zu übernehmen und diese und die Datei auf temp zu setzen ... Siehe auch die Erklärung unten auf http://www.linfo.org/cat .html .
Ich -f
habe den mv
Befehl auch hinzugefügt , um zu vermeiden, dass beim Überschreiben von Dateien nach Bestätigungen gefragt wird.
So verwenden Sie ein Verzeichnis:
for file in *; do printf "${PWD##*/}\n" | cat - $file > temp && mv -f temp $file; done
Beachten Sie auch, dass dadurch Pfade mit Leerzeichen unterbrochen werden. An anderer Stelle gibt es Lösungen (z. B. Dateiglobbing oderfind . -type f ...
Lösungen vom Typ) für diese.
ADDENDUM: Betreff: Mein letzter Kommentar: Mit diesem Skript können Sie Verzeichnisse mit Leerzeichen in den Pfaden durchsuchen:
#!/bin/bash
## /programming/4638874/how-to-loop-through-a-directory-recursively-to-delete-files-with-certain-extensi
## To allow spaces in filenames,
## at the top of the script include: IFS=$'\n'; set -f
## at the end of the script include: unset IFS; set +f
IFS=$'\n'; set -f
# ----------------------------------------------------------------------------
# SET PATHS:
IN="/mnt/Vancouver/Programming/data/claws-test/corpus test/"
# /superuser/716001/how-can-i-get-files-with-numeric-names-using-ls-command
# FILES=$(find $IN -type f -regex ".*/[0-9]*") ## recursive; numeric filenames only
FILES=$(find $IN -type f -regex ".*/[0-9 ]*") ## recursive; numeric filenames only (may include spaces)
# echo '$FILES:' ## single-quoted, (literally) prints: $FILES:
# echo "$FILES" ## double-quoted, prints path/, filename (one per line)
# ----------------------------------------------------------------------------
# MAIN LOOP:
for f in $FILES
do
# Tag top of file with basename of current dir:
printf "[top] Tag: ${PWD##*/}\n\n" | cat - $f > temp && mv -f temp $f
# Tag bottom of file with basename of current dir:
printf "\n[bottom] Tag: ${PWD##*/}\n" >> $f
done
unset IFS; set +f
sed
.