我正在尝试处理一个包含以科学计数法表示的数字但没有e
符号(即1.2e+3
写为)的文件1.2+3
。
我想到的最简单的方法awk
是使用函数替换+
为e+
,gsub
并在新文件中进行计算。减号情况也是如此。因此,可以使用以下命令完成简单的修复
awk '{gsub("+", "e+", $1); print $1, $2, $3, $4, $5}' file_in
并在所有列中执行相同操作。
但是,该文件还包含负数,这使事情变得更加复杂。可以看到一个示例文件
1.056000+0 5.000000-1 2.454400-3 2.914800-2 8.141500-6
2.043430+1 5.000000-1 2.750500-3 2.698100-2-2.034300-4
3.829842+1 5.000000-1 1.969923-2 2.211364-2 9.499900-6
4.168521+1 5.000000-1 1.601262-2 3.030919-2-3.372000-6
6.661784+1 5.000000-1 5.250575-2 3.443669-2 2.585500-5
7.278104+1 5.000000-1 2.137055-2 2.601701-2 8.999800-5
9.077287+1 5.000000-1 1.320498-2 2.961020-2-1.011600-5
9.248130+1 5.000000-1 3.069610-3 2.786329-2-6.317000-5
1.049935+2 5.000000-1 4.218794-2 3.321955-2-5.097000-6
1.216283+2 5.000000-1 1.432105-2 3.077165-2 4.300300-5
关于如何使用此类文件进行操作和计算的任何想法?
2
您想如何使用2.698100e-2-2.034300e-4这样的格式进行计算?
—
ctac_
看起来好像应该将其解析为固定宽度的列数据。列之间的明显空白只是数字格式的假象,它显示带前导空格而不是加号的正值。
—
Ilmari Karonen