
У меня есть текстовый файл следующего содержания:
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
Во-первых, я удаляю все строки по умолчанию после "<< IGS core stations >>" с помощью этой команды;
sed -i '/GPS/d' ./text.data
Затем мне нужно добавить введенный пользователем 4-символьный идентификатор с указанным выше форматом строки:
echo -n "###ids?####"
read ids
предположим, что пользовательский ввод brmu ista ankr
. Тогда файл text.data должен быть следующим;
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
Как я могу вставить эти входные данные с помощью цикла в текстовый файл определенного формата, как указано выше?
решение1
Я бы использовал 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
выходы
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
решение2
Вы можете сделать:
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
Это будет цикл по каждому слову $ids
и использовать printf
его для печати в желаемом формате. Это ${i^^}
делает переменную ВЕРХНЕЙ БУКВОЙ.