Código
#!/bin/bash
startTimes=$(seq 300 10 330)
for startTime in ${startTimes[@]};
do
endTime=${startTime}+10
echo ${endTime} > /tmp/111test # Output literally: startTimes+10
done
echo "Last endTime: "${endTime}
Salida conbash -x ...
++ seq 300 10 330
+ startTimes='300
310
320
330'
+ for startTime in '${startTimes[@]}'
+ endTime=300+10
+ echo 300+10
+ for startTime in '${startTimes[@]}'
+ endTime=310+10
+ echo 310+10
+ for startTime in '${startTimes[@]}'
+ endTime=320+10
+ echo 320+10
+ for startTime in '${startTimes[@]}'
+ endTime=330+10
+ echo 330+10
+ echo 'Last endTime: 330+10'
Last endTime: 330+10
Rendimiento esperado
310
320
330
340
SO: Debian 8.5
Kernel de Linux: 4.6 backsports
Respuesta1
La respuesta de don_crissti en los comentarios que señala dos errores en la declaración startTimes
y el uso ${var[@]}
que deben usarse con seq
la salida.
startTimes=( $(seq 300 10 330) )
for startTime in "${startTimes[@]}";
do
endTime=$(( ${startTime}+10 ))
echo ${endTime} > /tmp/111test
done
echo "Last endTime: "${endTime}