テキストファイル内の算術演算

テキストファイル内の算術演算

次のようなデータファイルがあります。

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

この問題を解決するためのワンライナーは次のとおりですawk

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

これは、各行で、最初のフィールドを 3600 ( ) で割り、小数点 2 桁 ( ) の後にスペースが続く$1/3600浮動小数点数として出力し、2 番目のフィールド ( ) を文字列 ( ) として出力し、最後に改行します。代わりに、たとえば小数点 6 桁に丸めたい場合は、を に変更するだけです。%.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

答え2

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

まず、行を 2 つのフィールドに分割し、最初のフィールドを 3600 で割って小数点 2 桁を出力し、新しい数値と行の 2 番目の数値を output という名前のファイルに出力します。

エラー チェックは行われません。エラーが発生した場合は、結果が異なる場合があります。

関連情報