这是我的代码:

x = 1.0
y = 100000.0    
print x/y

我的商显示为1.00000e-05。

有没有办法压制科学符号,让它显示为 0.00001 ?我将使用结果作为字符串。


当前回答

我也遇到过类似的问题,用我的解决方案:

from decimal import Decimal

Decimal(2/25500)
#output:0.00007843137254901961000728982664753630160703323781490325927734375

其他回答

使用3.6.4时,我遇到了一个类似的问题,当使用这个时,输出文件中的一个数字将被科学符号格式化:

fout.write('someFloats: {0:0.8},{1:0.8},{2:0.8}'.format(someFloat[0], someFloat[1], someFloat[2]))

我所要做的就是添加'f'来修复它:

fout.write('someFloats: {0:0.8f},{1:0.8f},{2:0.8f}'.format(someFloat[0], someFloat[1], someFloat[2]))

由于这是谷歌上的顶部结果,我将在这里发布失败后,为我的问题找到一个解决方案。如果你想格式化一个浮点对象的显示值,并让它保持一个浮点,而不是一个字符串,你可以使用这个解决方案:

创建一个新类,用于修改浮点值的显示方式。

from builtins import float
class FormattedFloat(float):

    def __str__(self):
        return "{:.10f}".format(self).rstrip('0')

您可以通过更改{:f}中的整数值来自己修改精度。

如果它是一个字符串,那么使用内置的float对其进行转换,例如: 打印(“%。5f" %浮动("1.43572 -03")) 答案:0.00143572

在Python的新版本(2.6及更高版本)中,你可以使用" .format()来完成@SilentGhost建议的事情:

'{0:f}'.format(x/y)

对于numpy数组,可以使用suppress命令as进行抑制

import numpy as np
np.set_printoptions(suppress=True)