我该如何显示:
十进制('40800000000.00000000000000')为'4.08E + 10'?
我试过这个:
>>> '%E' % Decimal('40800000000.00000000000000')
'4.080000E+10'
但它有额外的0。
答案 0 :(得分:124)
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'
答案 1 :(得分:96)
以下是使用format()
函数的示例:
>>> "{:.2E}".format(Decimal('40800000000.00000000000000'))
'4.08E+10'
答案 2 :(得分:25)
鉴于你的号码
x = Decimal('40800000000.00000000000000')
从Python 3开始,
'{:.2e}'.format(x)
是推荐的方法。
e
表示您需要科学记数法,.2
表示您想要点后2位数。所以你会得到x.xxE±n
答案 3 :(得分:18)
没有人提到.format
方法的简短形式:
至少需要Python 3.6
f"{Decimal('40800000000.00000000000000'):.2E}"
(我相信它和Cees Timmerman一样,只是更短一些)
答案 4 :(得分:8)
请参阅Python string formatting中的表格以选择正确的格式布局。在你的情况下,它是%.2E
。
答案 5 :(得分:4)
我的小数对于%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
答案 6 :(得分:3)
这对我来说效果最好:
import decimal
'%.2E' % decimal.Decimal('40800000000.00000000000000')
# 4.08E+10
答案 7 :(得分:2)
要将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()
即可。
答案 8 :(得分:2)
我更喜欢Python 3.x方式。
cal = 123.4567
print(f"result {cal:.4E}")
4
表示浮动部分中显示的位数。
cal = 123.4567
totalDigitInFloatingPArt = 4
print(f"result {cal:.{totalDigitInFloatingPArt}E} ")
答案 9 :(得分:2)
这是“简单” 答案和评论的合并列表。
from decimal import Decimal
x = '40800000000.00000000000000'
# Converted to Float
x = Decimal(x)
# ===================================== # `Dot Format`
print("{0:.2E}".format(x))
# ===================================== # `%` Format
print("%.2E" % x)
# ===================================== # `f` Format
print(f"{x:.2E}")
# =====================================
# ALL Return: 4.08E+10
print((f"{x:.2E}") == ("%.2E" % x) == ("{0:.2E}".format(x)))
# True
print(type(f"{x:.2E}") == type("%.2E" % x) == type("{0:.2E}".format(x)))
# True
# =====================================
IMPORT
的# NO IMPORT NEEDED FOR BASIC FLOATS
y = '40800000000.00000000000000'
y = float(y)
# ===================================== # `Dot Format`
print("{0:.2E}".format(y))
# ===================================== # `%` Format
print("%.2E" % y)
# ===================================== # `f` Format
print(f"{y:.2E}")
# =====================================
# ALL Return: 4.08E+10
print((f"{y:.2E}") == ("%.2E" % y) == ("{0:.2E}".format(y)))
# True
print(type(f"{y:.2E}") == type("%.2E" % y) == type("{0:.2E}".format(y)))
# True
# =====================================
# =====================================
x
# Decimal('40800000000.00000000000000')
y
# 40800000000.0
type(x)
# <class 'decimal.Decimal'>
type(y)
# <class 'float'>
x == y
# True
type(x) == type(y)
# False
x
# Decimal('40800000000.00000000000000')
y
# 40800000000.0
因此对于Python 3,您现在可以在这三个之间切换。
我的收藏夹:
print("{0:.2E}".format(y))
答案 10 :(得分:1)
这是我能找到的最简单的一个。
format(40800000000.00000000000000, '.2E')
#'4.08E+10'
(“ E”不区分大小写。您也可以使用“ .2e”)
答案 11 :(得分:0)
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