如何将科学记数法转换为浮点数? 这是我想要避免的一个例子:
Python 2.7.3 (default, Apr 14 2012, 08:58:41) [GCC] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> a=[78.40816326530613, 245068094.16326532]
>>> print a[0]/a[1]
3.19944395589e-07
>>> print float(a[0]/a[1])
3.19944395589e-07
>>> print float(a[0])/float(a[1])
3.19944395589e-07
答案 0 :(得分:10)
使用字符串格式:
>>> "{:.50f}".format(float(a[0]/a[1]))
'0.00000031994439558937568872208504280885144055446290'
答案 1 :(得分:8)
科学记数法只是打印浮点数的便捷方式。当你的例子中有很多前导零时,科学记数法可能更容易阅读。
为了在小数点后打印特定位数,您可以使用print指定格式字符串:
print 'Number is: %.8f' % (float(a[0]/a[1]))
或者您可以像其他答案一样使用format()
。
答案 2 :(得分:4)
这已经是一个浮点数,它只是以友好的格式打印。如果要在打印时显示一定数量的小数位,请使用format
:
>>> print format(a[0]/a[1], '.65f')
0.00000031994439558937568872208504280885144055446289712563157081604