以科学计数法显示小数点

我如何显示这个:

十进制('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' 

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

 >>> "{:.2E}".format(Decimal('40800000000.00000000000000')) '4.08E+10' 
  • 官方文件

  • 原始格式()build议

查看Pythonstring格式的表格来select正确的格式布局。 你的情况是%.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 

给你的号码

 x = Decimal('40800000000.00000000000000') 

从Python 3开始,

 '{:.2e}'.format(x) 

是推荐的方法。

e意味着你想要科学记数法,并且.2意味着你需要2个数字点。 所以你会得到x.xxE±n

若要将十进制转换为科学记数法,而不需要指定格式string中的精度,并且不包括尾随零,我目前正在使用

 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()

这对我最有效:

 import decimal '%.2E' % decimal.Decimal('40800000000.00000000000000') # 4.08E+10 
 def formatE_decimal(x, prec=2): """ Examples: >>> formatE_decimal('0.1613965',10) '1.6139650000E-01' >>> formatE_decimal('0.1613965',5) '1.61397E-01' >>> formatE_decimal('0.9995',2) '1.00E+00' """ xx=decimal.Decimal(x) if type(x)==type("") else x tup = xx.as_tuple() xx=xx.quantize( decimal.Decimal("1E{0}".format(len(tup[1])+tup[2]-prec-1)), decimal.ROUND_HALF_UP ) tup = xx.as_tuple() exp = xx.adjusted() sign = '-' if tup.sign else '' dec = ''.join(str(i) for i in tup[1][1:prec+1]) if prec>0: return '{sign}{int}.{dec}E{exp:+03d}'.format(sign=sign, int=tup[1][0], dec=dec, exp=exp) elif prec==0: return '{sign}{int}E{exp:+03d}'.format(sign=sign, int=tup[1][0], exp=exp) else: return None