gpt4 book ai didi

python - .quantize() 的小数舍入不使用原始上下文

转载 作者:行者123 更新时间:2023-11-28 21:12:55 27 4
gpt4 key购买 nike

如果我执行以下操作,我希望 0.005 向上舍入为 0.01 而不是向下舍入为 0.00,因为舍入设置为ROUND_HALF_UP

>>> import decimal
>>> currency = decimal.Context(rounding=decimal.ROUND_HALF_UP)
>>> cents = decimal.Decimal('0.00')
>>> amount = currency.create_decimal('0.005')
>>> amount
Decimal('0.005')
>>> amount.quantize(cents)
Decimal('0.00')

但是如果我将 currency 传递给 quantize(),它会正确舍入:

>>> amount.quantize(cents, context=currency)
Decimal('0.01')

为什么 amount(从 currency 上下文创建)不使用 currency 上下文进行舍入?

注意:这个问题不是问如何四舍五入到小数点后两位。我只是以此为例。我想知道为什么Context 创建的 Decimal 在量化/舍入时不使用相同的 Context .

最佳答案

Decimal 对象不保留创建它们的上下文。使用特定上下文的小数操作,例如带有上下文参数的 Context.create_decimalDecimal.quantize,只会覆盖该操作的全局上下文;对生成的 Decimal 的进一步操作是在全局上下文中完成的。

如果你想让所有操作都使用ROUND_HALF_UP,你可以设置全局上下文:

decimal.setcontext(currency)

但如果您想混合上下文,则必须为每个需要全局上下文以外的上下文的操作显式提供上下文。

关于python - .quantize() 的小数舍入不使用原始上下文,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33678723/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com