арифметическая операция в текстовом файле

У меня есть файл данных следующим образом:

569158.650000 8.859e-02
579175.970000 8.659e-02
599177.990000 8.659e-02

Мне нужно извлечь значение первой строки из первого столбца. Затем мне нужно разделить первый столбец на 3600. Наконец, мне нужно вставить результаты в качестве первого столбца в новый файл данных следующим образом:

0 8.859e-02
2.78 8.659e-02
8.33 8.659e-02

Как я могу выполнить приведенные выше вычисления с использованием кодов?

1
задан 17 June 2019 в 18:44

2 ответа

Вот awk oneliner для решения проблемы:

awk '{printf "%.2f %s\n", $1/3600, $2}'

Для каждой строки это просто делит первое поле на 3600 ($1/3600) и печатает его как число с плавающей запятой с двумя десятичными знаками ( %.2f), затем пробел, второе поле ($2) в виде строки (%s) и, наконец, перевод строки. Если вы хотите округлить, например, до вместо этого шесть знаков после запятой, просто измените %.2f на %.6f.

Пример прогона

$ cat <data
569158.650000 8.859e-02
579175.970000 8.659e-02
599177.990000 8.659e-02
$ awk '{printf "%.2f %s\n", $1/3600, $2}' <data >new_data
$ cat <new_data 
158.10 8.859e-02
160.88 8.659e-02
166.44 8.659e-02
$ awk '{printf "%.6f %s\n", $1/3600, $2}' <data
158.099625 8.859e-02
160.882214 8.659e-02
166.438331 8.659e-02
3
ответ дан 17 June 2019 в 18:44
#!/bin/bash                                                                     
div=3600 #Divisor
scale=2  #Scale for output. Number of digits after decimal point.
while read -r line #Read file into variable line, line by line.
do
    firstnum=$(echo $line | cut -d " " -f 1) #Pick the first number field
    secondnum=$(echo $line | cut -d " " -f 2) #Pick the second number field
    firstnum=$(echo "scale=${scale}; ${firstnum}/${div}" | bc -l) #Divide by $div with $scale places after decimal point.
    echo "${firstnum} ${secondnum}" >> output #Output first and second column, seperated by space,to file named output.
done < input #input is name of input file.

Этот сценарий читает из файла с именем input в указанном вами формате и выводит в файл с именем output.

Сначала он разбивает строку на два поля, а затем делит первое поле на 3600 с двумя напечатанными десятичными знаками, а затем печатает новое число и второе число из строки в файл с именем output.

Это не проверка ошибок. Если обнаружена ошибка, YMMV.

1
ответ дан 17 June 2019 в 18:44

Другие вопросы по тегам:

Похожие вопросы: