Que tal
awk 'NR == 1 {DELTA = $0} {$0 = ($0 - DELTA) * FAC; print}' FAC=627.509 file
Eu tenho um arquivo que contém alguns números
$ cat file.dat
0.092593
0.048631
0.027957
0.030699
0.026250
0.038156
0.011823
0.013284
0.024529
0.022498
0.013217
0.007105
0.018916
0.014079
Eu quero subtrair o primeiro número de todos os outros números e, em seguida, multiplicar a diferença com 627,509. Saída esperada
$ cat newfile.dat
0.000000
-27.586551
-40.559672
-38.839042
-41.630830
-34.159707
-50.683902
-49.767111
-42.710773
-43.985243
-49.809154
-53.644489
-46.232981
-49.268242
Supondo que eu queira fazer isso com o awk, eu preciso criar uma variável contendo o primeiro número antes da instrução awk, por exemplo
factor=$(head -1 myfile.dat)
ou posso fazer isso completamente com o awk?
Que tal
awk 'NR == 1 {DELTA = $0} {$0 = ($0 - DELTA) * FAC; print}' FAC=627.509 file
Isso parece funcionar:
$ awk -v c=627.509 'NR==1 { b=$1 } { printf( "%0.6f\n", ( $1-b ) * c ) }' file.dat
0.000000
-27.586551
-40.559672
-38.839042
-41.630830
-34.159707
-50.683902
-49.767111
-42.710773
-43.985243
-49.809154
-53.644489
-46.232981
-49.268242
Tags awk