以科学计数法显示小数点
我如何显示这个:
十进制('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