
Tengo un archivo de texto de la siguiente manera;
SITE FIX --COORD.CONSTR.--
<< default for regional stations >>
ALL NNN 100. 100. 100.
<< IGS core stations >>
VILL VILL_GPS NNN 0.050 0.050 0.05
MAS1 MAS1_GPS NNN 0.050 0.050 0.05
En primer lugar, elimino todas las líneas predeterminadas después de "<< estaciones centrales IGS >>" con este comando;
sed -i '/GPS/d' ./text.data
Luego necesito agregar la identificación de 4 caracteres de entrada del usuario con el formato de línea anterior como;
echo -n "###ids?####"
read ids
asumir la entrada del usuario brmu ista ankr
. Entonces el archivo text.data debe ser el siguiente;
SITE FIX --COORD.CONSTR.--
<< default for regional stations >>
ALL NNN 100. 100. 100.
<< IGS core stations >>
BRMU BRMU_GPS NNN 0.050 0.050 0.05
ISTA ISTA_GPS NNN 0.050 0.050 0.05
ANKR ANKR_GPS NNN 0.050 0.050 0.05
¿Cómo puedo insertar estas entradas con bucle en el archivo de texto con un formato específico como el anterior?
Respuesta1
Yo usaría awk:
read ids
# some validation here...
awk -v input="$ids" '
BEGIN {
n = split(toupper(input), user)
fmt = "%-4s %-8s NNN 0.050 0.050 0.05\n"
}
{print}
/<< IGS core stations >>/ {
for (i=1; i<=n; i++)
printf fmt, user[i], user[i]"_GPS"
exit
}
' ./text.data
salidas
SITE FIX --COORD.CONSTR.--
<< default for regional stations >>
ALL NNN 100. 100. 100.
<< IGS core stations >>
BRMU BRMU_GPS NNN 0.050 0.050 0.05
ISTA ISTA_GPS NNN 0.050 0.050 0.05
ANKR ANKR_GPS NNN 0.050 0.050 0.05
Respuesta2
Podrías hacerlo:
sed -i '/GPS/d' text.data; read -p "###ids?####" ids; for i in $ids; do
printf '%s\t%s_GPS\tNNN\t0.050\t0.050\t0.05\n' "${i^^}" "${i^^}"
done >> text.data
Eso recorrerá cada palabra $ids
y printf
la usará para imprimirla en el formato deseado. Esto ${i^^}
hace que la variable sea MAYÚSCULAS.