我如何显示十进制('40800000000.00000000000000')为'4.08E+10'?
我试过了:
>>> '%E' % Decimal('40800000000.00000000000000')
'4.080000E+10'
但是它有多余的0。
我如何显示十进制('40800000000.00000000000000')为'4.08E+10'?
我试过了:
>>> '%E' % Decimal('40800000000.00000000000000')
'4.080000E+10'
但是它有多余的0。
当前回答
要将Decimal转换为科学计数法,而不需要在格式字符串中指定精度,并且不包括后面的零,我目前正在使用
def sci_str(dec):
return ('{:.' + str(len(dec.normalize().as_tuple().digits) - 1) + 'E}').format(dec)
print( sci_str( Decimal('123.456000') ) ) # 1.23456E+2
要保留任何后面的零,只需删除normalize()。
其他回答
给定你的数字
x = Decimal('40800000000.00000000000000')
从Python 3开始,
'{:.2e}'.format(x)
是推荐的方法。
E表示你想要科学记数法,.2表示你想要点号后面有两位数字。得到x。xxe±n
请参阅Python字符串格式中的表格,以选择适当的格式布局。在你的例子中是%. 2e。
没有人提到.format方法的缩写形式:
至少需要Python 3.6
f"{Decimal('40800000000.00000000000000'):.2E}"
(我相信它和Cees Timmerman一样,只是短一点)
这对我来说效果最好:
import decimal
'%.2E' % decimal.Decimal('40800000000.00000000000000')
# 4.08E+10
我更喜欢Python 3。x。
cal = 123.4567
print(f"result {cal:.4E}")
4表示浮动部分显示了多少位数字。
cal = 123.4567
totalDigitInFloatingPArt = 4
print(f"result {cal:.{totalDigitInFloatingPArt}E} ")