operação aritmética em arquivo de texto

operação aritmética em arquivo de texto

Eu tenho um arquivo de dados como segue;

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

Preciso extrair o valor da primeira linha da primeira coluna. Então preciso dividir a primeira coluna por 3600. Finalmente, preciso colar os resultados como a primeira coluna em um novo arquivo de dados da seguinte maneira;

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

Como posso fazer o cálculo acima usando códigos?

Responder1

Aqui está um awkoneliner para resolver o problema:

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

Para cada linha, isso simplesmente divide o primeiro campo por 3600 ( $1/3600) e o imprime como um ponto flutuante com duas casas decimais ( %.2f) seguido de espaço, o segundo campo ( $2) como uma string ( %s) e finalmente uma nova linha. Se você quiser arredondar para, por exemplo, seis casas decimais, basta alterar %.2fpara %.6f.

Exemplo de execução

$ 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

Responder2

#!/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.

Este script lê um arquivo nomeado inputno formato que você disse e gera um arquivo chamado output.

Primeiro ele corta a linha em dois campos e depois divide o primeiro campo por 3600 com duas casas decimais impressas e depois imprime o novo número e o segundo número da linha em um arquivo chamado output.

Não faz verificação de erros. Se um erro for encontrado, YMMV.

informação relacionada