PROBLÈME: balisez un fichier, en haut du fichier, avec le nom de base du répertoire parent.
C'est-à-dire, pour
/mnt/Vancouver/Programming/file1
balisez le haut de file1
avec Programming
.
SOLUTION 1 - fichiers non vides:
bn=${PWD##*/} ## bn: basename
sed -i '1s/^/'"$bn"'\n/' <file>
1s
place le texte à la ligne 1 du fichier.
SOLUTION 2 - fichiers vides ou non vides:
La sed
commande ci-dessus échoue sur les fichiers vides. Voici une solution, basée sur /superuser/246837/how-do-i-add-text-to-the-beginning-of-a-file-in-bash/246841#246841
printf "${PWD##*/}\n" | cat - <file> > temp && mv -f temp <file>
Notez que la -
commande in the cat est obligatoire (lit l'entrée standard: voir man cat
pour plus d'informations). Ici, je crois, il faut prendre la sortie de l'instruction printf (vers STDIN), et cat ça et le fichier à temp ... Voir aussi l'explication au bas de http://www.linfo.org/cat .html .
J'ai également ajouté -f
à la mv
commande, pour éviter qu'on me demande des confirmations lors du remplacement des fichiers.
Pour récapituler sur un répertoire:
for file in *; do printf "${PWD##*/}\n" | cat - $file > temp && mv -f temp $file; done
Notez également que cela rompra les chemins avec des espaces; il existe des solutions ailleurs (par exemple, globalisation de fichiers ou find . -type f ...
solutions de type) pour celles-ci.
ADDENDA: Re: mon dernier commentaire, ce script va vous permettre de récursivement sur des répertoires avec des espaces dans les chemins:
#!/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
.