如何解决Python decimal.Decimal 以科学记数法产生结果
我将一个很长的数字分成更小的数字。两者都是decimal.Decimal()类型。
结果以科学记数法显示。我该如何阻止?我需要完整打印数字。
>>> decimal.getcontext().prec
50
>>> val
Decimal('1000000000000000000000000')
>>> units
Decimal('1500000000')
>>> units / val
Decimal('1.5E-15')
解决方法
精度在内部保持 - 您只需在将十进制值导出为字符串时明确调用所需的小数位数。
因此,如果您要打印或在 HTML 模板中插入值,第一步是使用字符串格式方法(或 f-strings),以确保包含数字:
In [29]: print(f"{units/val:.50f}")
0.00000000000000150000000000000000000000000000000000
不幸的是,string-format minilanguage 无法自行消除右侧的冗余零。 (左边可以填充“0”、“”、自定义字符,随心所欲,但十进制分隔符后的所有精度都转换为尾随0)。
由于找到最不重要的非零数字很复杂 - 否则我们可以使用从数字中提取的参数而不是“50”来提高格式表达式的精度,更简单的方法是在格式化后删除这些零,使用字符串 .rstrip
方法:
In [30]: print(f"{units/val:.50f}".rstrip("0"))
0.0000000000000015
简而言之:这似乎是唯一的方法:在所有接口点中,数字离开核心到输出,在那里它被表示为一个字符串,你用固定的精度对其进行格式化点符号,并用 f-string 去掉尾随的零:
return template.render(number=f"{number:.50f}".rstrip("0"),...)
,
将十进制数渲染成带有浮点类型指示符 {:f}
的格式化字符串,它会显示恰到好处的位数来表示整数,无论它是非常大的整数还是非常大的整数大十进制。
>>> val
Decimal('1000000000000000000000000')
>>> units
Decimal('1500000000')
>>> "{:,f}".format(units / val)
'0.0000000000000015'
# very large decimal integer,formatted as float-type string,appears without any decimal places at all when it has none! Nice!
>>> "{:,f}".format(units * val)
'1,500,000,000'
您不需要指定小数位。它将仅显示表达数字所需的数量,当小数点小于固定格式宽度时,会省略出现在最后一个小数位后的那串无用的零。如果数字没有小数部分,您就不会得到任何小数位。
非常大的数字因此可以容纳,而无需再次猜测它们的大小。而且您也不必再猜测它们是否有小数位。
任何指定的千位分隔符 {:,f}
同样只有在数字是大整数而不是长小数时才有效。
附则
然而,Decimal() 有这种重要位置的想法,如果它认为你想要它们,它会添加尾随零。
这个想法是它可以智能地处理您可能会处理货币数字(例如 £ 10.15
)的情况。要使用 documentation 中的示例:
>>> decimal.Decimal('1.30') + decimal.Decimal('1.20')
Decimal('2.50')
如果您格式化 Decimal() 没有任何区别 - 如果 Decimal() 认为它很重要,您仍然会得到尾随零:
>>> "{:,f}".format( decimal.Decimal('1.30') + decimal.Decimal('1.20'))
'2.50'
当您将千位和分数放在一起处理时,会发生同样的事情(也许是出于某种充分的理由?):
>>> decimal.Decimal(2500) * decimal.Decimal('0.001')
Decimal('2.500')
使用 Decimal().normalize() 方法删除重要的尾随零:
>>> (2500 * decimal.Decimal('0.001')).normalize()
Decimal('2.5')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。