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

我试过了:

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

但是它有多余的0。


当前回答

from decimal import Decimal

'%.2E' % Decimal('40800000000.00000000000000')

# returns '4.08E+10'

在你的'40800000000.00000000000000'中,有许多有效的零,它们与任何其他数字具有相同的含义。这就是为什么你必须明确地说出你想停在哪里。

如果你想自动删除所有后面的零,你可以尝试:

def format_e(n):
    a = '%E' % n
    return a.split('E')[0].rstrip('0').rstrip('.') + 'E' + a.split('E')[1]

format_e(Decimal('40800000000.00000000000000'))
# '4.08E+10'

format_e(Decimal('40000000000.00000000000000'))
# '4E+10'

format_e(Decimal('40812300000.00000000000000'))
# '4.08123E+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()。

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

至少需要Python 3.6

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

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

这是我能找到的最简单的一个。

format(40800000000.00000000000000, '.2E')
#'4.08E+10'

(“E”不区分大小写。你也可以用'.2e')

我的小数对于%E来说太大了,所以我不得不即兴发挥:

def format_decimal(x, prec=2):
    tup = x.as_tuple()
    digits = list(tup.digits[:prec + 1])
    sign = '-' if tup.sign else ''
    dec = ''.join(str(i) for i in digits[1:])
    exp = x.adjusted()
    return '{sign}{int}.{dec}e{exp}'.format(sign=sign, int=digits[0], dec=dec, exp=exp)

下面是一个用法示例:

>>> n = decimal.Decimal(4.3) ** 12314
>>> print format_decimal(n)
3.39e7800
>>> print '%e' % n
inf

请参阅Python字符串格式中的表格,以选择适当的格式布局。在你的例子中是%. 2e。