私はbashスクリプトを書いていますが、神秘的なループに陥っています。
私はいくつかのコードを含むテキストファイル(codigos.txt)で特定のコードを見つけなければなりません。次のwhileループを作成しました(ここで、 $siguienteCodigo は検索するコードを含む変数で、 $rutaOrigen はコードを含む codigos.txt ファイルへのパスです)。
while grep -F "$siguienteCodigo" "$rutaOrigen/codigos.txt"; do
let siguienteCodigo++
done
ところで、スクリプトを実行してみると驚くほどコードを探しているようでしたが、codigos.txtファイルが削除されていました!
完全なスクリプトは次のとおりです。
#!/bin/bash
#
################################################################################
# SCRIPT PARA CODIFICAR RECURSIVAMENTE TODAS LAS FOTOGRAFÍAS DE LOS ARTÍCULOS #
# Y REGISTRARLAS EN UNA HOJA DE CÁLCULO DE MICROSOFT EXCEL #
################################################################################
#
# Extraemos el día, mes, año, hora, minuto y segundo
day="$(date +%d)"
month="$(date +%m)"
year="$(date +%Y)"
hour="$(date +%H)"
minute="$(date +%M)"
second="$(date +%S)"
# Extraemos la ruta de origen, donde se ejecuta el script
rutaOrigen="$(pwd)"
# Recorremos todos los directorios listados recursivamente, a partir de la ruta
# de origen
for d in $(ls -R | grep "^\." | sed 's/://'); do
# Cambiamos al directorio
cd "$d"
# Buscamos cuál es el último artículo codificado
ultimoCodigo=$(printf "%08d" "0")
# Recorremos todos los archivos que nos interesa listar, que son todos
# los archivos con extensión .jpg .JPG y .txt
for i in $(ls *.jpg *.JPG *.txt); do
# Extraemos el nombre del archivo, sin extensión
case "${i##*.}" in
"jpg")
fotoActual="$(basename -s ".jpg" "$i")";;
"JPG")
fotoActual="$(basename -s ".JPG" "$i")";;
"txt")
fotoActual="$(basename -s ".txt" "$i")";;
esac
# Extraemos los 8 primeros carácteres del archivo, que
# corresponderán al "código 8" del artículo
codigo8=$(expr substr "$fotoActual" 1 8)
# Si los 8 primeros carácteres del archivo forman un numérico
# entero y éste es mayor que el último "codigo 8" guardado,
# inicialmente iniciado a 0...
if [[ $codigo8 =~ ^[0-9]+$ ]] && (( codigo8 > ultimoCodigo )); then
# Guardamos el "código 8" actual como el último código,
# es decir, como el último artículo codificado
ultimoCodigo=$(printf "%08d" "$codigo8")
fi
done
# Volvemos a recorrer todos los archivos que nos interesa listar, esta
# vez para codificar los que no están codificados, es decir, los que
# siguen al último artículo codificado
for i in $(ls *.jpg *.JPG *.txt); do
# Extraemos el nombre del archivo, sin extensión
case "${i##*.}" in
"jpg")
fotoActual="$(basename -s ".jpg" "$i")";;
"JPG")
fotoActual="$(basename -s ".JPG" "$i")";;
"txt")
fotoActual="$(basename -s ".txt" "$i")";;
esac
# Extraemos los 8 primeros carácteres del archivo, que
# corresponderán al "código 8" del artículo
codigo8=$(expr substr "$fotoActual" 1 8)
siguienteCodigo=$(($ultimoCodigo + 1))
# Si los 8 primeros carácteres del archivo forman un numérico
# entero y éste es mayor que el último "código 8" guardado...
if [[ $codigo8 =~ ^[0-9]+$ ]] && (( codigo8 <= ultimoCodigo )); then
:
else
while grep -F "$siguienteCodigo" "$rutaOrigen/codigos.txt"; do
let siguienteCodigo++
done
rutaActual="$(pwd)"
carpetaActual="$(basename "$rutaActual")"
caracteresCarpeta=$(expr length "$carpetaActual")
descripcion="$(expr substr "$carpetaActual" 10 $caracteresCarpeta)"
rutaActual="$(echo -e "$rutaActual" | sed 's/\//\\/g' | sed 's/\\media\\sf_E_DRIVE/E:/')"
let ultimoCodigo++
newFile=$(printf "%08d_${day}-${month}-${year}_${hour}-${minute}-${second}.jpg" "$siguienteCodigo")
mv -- "$i" "$newFile"
echo -e "$siguienteCodigo\t$rutaActual\t$descripcion\t$day/$month/$year\t$hour:$minute:$second" | awk -F '\t' '{print $1,$2,$3,$4,$5}' OFS='\t' >> "$rutaOrigen/registroarticulos.xls"
fi
done
cd "$rutaOrigen"
done
echo "Se creó una hoja de registro en $rutaOrigen/registroarticulos.xls"
echo "Todas las fotografías fueron codificadas correctamente :)"
exit 0
ベストアンサー1
スクリプトはファイルを処理してい.JPG
ます。.jpg
.txt
ファイル名は、出力から派生したディレクトリで最初に実行されたときにcodigos.txt
変更されます。.
$(ls -R | grep "^\." | sed 's/://')
マイコンピュータでテストを実行すると、ファイル名がcodigos.txt
次のように変更されました。00000002_02-10-2015_13-18-59.jpg