我如何显示十进制('40800000000.00000000000000')为'4.08E+10'?

我试过了:

>>> '%E' % Decimal('40800000000.00000000000000')
'4.080000E+10'

但是它有多余的0。


当前回答

这对我来说效果最好:

import decimal
'%.2E' % decimal.Decimal('40800000000.00000000000000')
# 4.08E+10

其他回答

要将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()。

添加一个更新的答案,以展示如何仅将e符号应用于小数字

value = 0.1
a = "{:,}".format(value) if value >= 0.001 else "{:,.3e}".format(value)
print(a) # 0.1

value = 0.00002488
a = "{:,}".format(value) if value >= 0.001 else "{:,.3e}".format(value)
print(a) # 2.488e-05

我更喜欢Python 3。x。

cal = 123.4567
print(f"result {cal:.4E}")

4表示浮动部分显示了多少位数字。

cal = 123.4567
totalDigitInFloatingPArt = 4
print(f"result {cal:.{totalDigitInFloatingPArt}E} ")

没有人提到.format方法的缩写形式:

至少需要Python 3.6

f"{Decimal('40800000000.00000000000000'):.2E}"

(我相信它和Cees Timmerman一样,只是短一点)

下面是一个使用format()函数的例子:

>>> "{:.2E}".format(Decimal('40800000000.00000000000000'))
'4.08E+10'

除了format,你还可以使用f-strings:

>>> f"{Decimal('40800000000.00000000000000'):.2E}"
'4.08E+10'

官方文档 原始格式()提案