Se você quiser escrever a data da criação do arquivo de imagem na própria imagem (se não é isso que você deseja, edite sua pergunta), você pode usá-lo imagemagick
.
Instale o ImageMagick se ainda não estiver instalado:
sudo apt-get install imagemagick
Execute um loop bash que obtenha a data de criação de cada foto e use a convert
partir do imagemagick
conjunto para editar a imagem:
for img in *jpg; do convert "$img" -gravity SouthEast -pointsize 22 \
-fill white -annotate +30+30 %[exif:DateTimeOriginal] "time_""$img";
done
Para cada imagem nomeada foo.jpg
, isso criará uma cópia chamada time_foo.jpg
com o carimbo de hora no canto inferior direito. Você pode fazer isso de maneira mais elegante, para vários tipos de arquivos e nomes de saída agradáveis, mas a sintaxe é um pouco mais complexa:
OK, essa era a versão simples. Escrevi um script que pode lidar com situações mais complexas, arquivos em subdiretórios, nomes de arquivos estranhos etc. Até onde eu sei, apenas imagens .png e .tif podem conter dados EXIF, portanto, não há sentido em executá-lo em outros formatos. . No entanto, como uma possível solução alternativa, você pode usar a data de criação do arquivo em vez dos dados do EIF. Provavelmente, isso não é o mesmo que a data em que a imagem foi tirada; portanto, o script abaixo tem a seção relevante comentada. Remova os comentários se você quiser processar dessa maneira.
Salve este script como add_watermark.sh
e execute-o no diretório que contém seus arquivos:
bash /path/to/add_watermark.sh
Ele usa os exiv2
quais você pode precisar instalar ( sudo apt-get install exiv2
). O script:
#!/usr/bin/env bash
## This command will find all image files, if you are using other
## extensions, you can add them: -o "*.foo"
find . -iname "*.jpg" -o -iname "*.jpeg" -o -iname "*.tif" -o \
-iname "*.tiff" -o -iname "*.png" |
## Go through the results, saving each as $img
while IFS= read -r img; do
## Find will return full paths, so an image in the current
## directory will be ./foo.jpg and the first dot screws up
## bash's pattern matching. Use basename and dirname to extract
## the needed information.
name=$(basename "$img")
path=$(dirname "$img")
ext="${name/#*./}";
## Check whether this file has exif data
if exiv2 "$img" 2>&1 | grep timestamp >/dev/null
## If it does, read it and add the water mark
then
echo "Processing $img...";
convert "$img" -gravity SouthEast -pointsize 22 -fill white \
-annotate +30+30 %[exif:DateTimeOriginal] \
"$path"/"${name/%.*/.time.$ext}";
## If the image has no exif data, use the creation date of the
## file. CAREFUL: this is the date on which this particular file
## was created and it will often not be the same as the date the
## photo was taken. This is probably not the desired behaviour so
## I have commented it out. To activate, just remove the # from
## the beginning of each line.
# else
# date=$(stat "$img" | grep Modify | cut -d ' ' -f 2,3 | cut -d ':' -f1,2)
# convert "$img" -gravity SouthEast -pointsize 22 -fill white \
# -annotate +30+30 "$date" \
# "$path"/"${name/%.*/.time.$ext}";
fi
done
convert.im6: unknown image property "%[exif:DateTimeOriginal]" @ warning/property.c/InterpretImageProperties/3245. convert.im6: unable to open image `{img/%.*/.time.jpg}': No such file or directory @ error/blob.c/OpenBlob/2638.
Além disso, ainda não decidi se ainda quero usar subdiretórios; você poderia mostrar como usarfind
também? Obrigado!