linux - 如何将linux或perl中特定列中的科学记数法更改为数字

标签 linux perl awk numerical scientific-notation

我有一个文件如下:

1   13.00000    12.9999999183917    8.160832898340686E-008  21148294
2   16.00000    15.9999995223584    -4.760327190211910E-007 21148294
3   9.000000    8.99999979262170    2.073783047507050E-007  21148295

我想要这样的输出:

1   13.00000    12.9999999183917    0.0000000816083289340686    21148294
2   16.00000    15.9999995223584    -0.00000004760327190211910  21148294
3   9.000000    8.99999979262170    0.00000002073783047507050   21148295

有人可以帮助我吗?非常感谢!!

最佳答案

这个问题的关键是使用printf来控制精度。

您应该给出预期的精度,例如第一行和第二行中的数字具有不同的精度。您期望哪一个?甚至更高?这是使用 awk 的示例。自己做一些测试并选择正确的。它至少应该为您指明道路,让您开始:

kent$  cat f
1   13.00000    12.9999999183917    8.160832898340686E-008  21148294
2   16.00000    15.9999995223584    -4.760327190211910E-007 21148294
3   9.000000    8.99999979262170    2.073783047507050E-007  21148295

kent$  awk '{$4=sprintf("%.23f",$4)}7' f
1 13.00000 12.9999999183917 0.00000008160832898340686 21148294
2 16.00000 15.9999995223584 -0.00000047603271902119099 21148294
3 9.000000 8.99999979262170 0.00000020737830475070501 21148295

kent$  awk '{$4=sprintf("%.24f",$4)}7' f 
1 13.00000 12.9999999183917 0.000000081608328983406864 21148294
2 16.00000 15.9999995223584 -0.000000476032719021190989 21148294
3 9.000000 8.99999979262170 0.000000207378304750705009 21148295

您可以更改%.xxf模式

关于linux - 如何将linux或perl中特定列中的科学记数法更改为数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24954877/

相关文章:

linux - 对 bash 行为感到困惑 - Bash/awk mystery

c - 当为 stdout 打开非阻塞 I/O 时,操作系统也为 stdin 打开它是否正确?

regex - 如何用 Perl 中的另一组替换文件中的一组单词?

awk - 使用 awk 或从 linux 上的命令行删除文件中的列

python - 其他优于基于 TCL 的 Expect 的解决方案/语言?

linux - 如何使用 awk 取出与其时间戳匹配的列表?

c++ - 编译为架构 x64 的库在 Arm 架构中出现错误

linux - 从堆栈中弹出和打印 argc

php - 如何在 Perl 中进行全局正则表达式匹配?

python - 依次运行多个命令行 linux python