
次の形式のデータ ファイル abc.txt があります。
BALT 1
54.500 -161.070
3.95863757
0.01691576
BARM 2
-9.200 67.120
4.07529868
0.01951653
BKSR 3
43.830 142.520
4.08919819
0.00587340
次の形式で変換する必要があります:
BALT 1
54.5000000 -161.070000
0.3958637E+01
0.1691576E-01
BARM 2
-9.20000000 67.1200000
0.4075298E+01
0.1951653E-01
BKSR 3
43.8300000 142.520000
0.4089198E+01
0.5873400E-02
2 行目の数字が占めるスペースの合計は、-ve 記号を除いて 10 である必要があります (例: 54.500 は 54.5000000、-161.070 は -161.070000)。3 行目と 4 行目のスペースは 13 である必要があります (例: 3.95863757 は 0.3958637E+01)。また、BALT または BARM は変数であり、4 文字の別の単語である可能性があります。
ありがとう。
答え1
バージョン3次のようなawkファイルを使用する
function tenth(x) {
u = x ; if ( u < 0 ) u = -x ;
b=10 ;
a=b-2 ;
if ( u >= 10 ) {
d=int(log(u)/log(10)) ;
a=b-d-1 ;
}
printf "%*.*f",b,a,x ;
}
length($1) == 4 { print ; next ;}
NF == 1 { d=int(log($1)/log(10)) ;if (d> -1) d++ ; printf " %.7fE%+03d\n",$1/(10^d),d ;}
NF == 2 { printf " " ; tenth($1); printf " " ; tenth($2) ; printf "\n" ;}
どこ
lengtht$1) == 4 { print ; next ;}
最初のフィールドが4文字の行はそのまま残します(ただし、1234の場合もあります)。function tenth(x)
: フォーマットを調整する関数を定義します。"%*.*f"
文字列は変換のサイズ/精度を調整します%f
。最初の * は b に置き換えられ、2 番目の * は a に置き換えられます。int(log()/log(10))
特定のニーズに合わせて表現を調整する 10 進ログを提供しますか?
一緒に使う
awk -f f.awk input
その結果として
BALT 1
54.5000000 -161.070000
0.3958638E+01
0.1691576E-01
BALT 2
-9.20000000 67.1200000
0.4075299E+01
0.1951653E-01
BALT 3
43.8300000 142.520000
0.4089198E+01
0.5873400E-02
0.00000000 1.00000000
-3.14150000 2.71828183
答え2
たとえば次のようになります:
awk '
!/[[:alpha:]]/{
if (NF == 1)
$0 = sprintf(" %.7E", $0 * 10)
else
$0 = sprintf(" %.8f %.8f", $1, $2)
}
{print}' | sed '
s/\([0-9.]\{10\}\)[0-9]*/\1/g
s/\([1-9]\)\.\(.*\).E/0.\1\2E/'
答え3
awk を使わずに取得するには、次のようにします。
while read line; do echo $line; read a; read b; read c; printf "%.7f %.7f\n %.7e\n %.7e\n" $a $b $c; done < data.txt
ただし、この方法で printf を使用すると、ピリオドの代わりにコンマを使用するロケールを使用している場合に問題が発生する可能性があります。この場合、次のように修正できます。
while read line; do echo $line; read a; read b; read c; LC_NUMERIC="en_US.UTF-8" printf "%.7f %.7f\n %.7e\n %.7e\n" $a $b $c; done < data.txt
もちろん、スクリプトでは、改行とインデントを使用してフォーマットを適切に行う必要があります。