我可能遗漏了一些必不可少的东西,但我无法找到一种方法来“正确”在 Python (2.7) 中舍入浮点数/小数,至少到小数点后三位。我所说的“正确”是指 1.2225 应该四舍五入到 1.223,而 1.2224 应该四舍五入到 1.222。

我知道 round 按照设计不适用于 Python 中的浮点数,但我似乎无法让 Decimalceil 函数按预期运行。最好寻找内置功能而不是自定义功能解决方法,但对两者都开放。

>>> x = 1.2225                                   # expected: 1.223
>>> round(x, 3)
1.222                                            # incorrect

>>> from math import ceil

>>> ceil(x * 1000.0) / 1000.0
1.223                                            # correct
>>> y = 1.2224                                   # expected: 1.222
>>> ceil(y * 1000.0) / 1000.0
1.223                                            # incorrect

>>> from decimal import Decimal, ROUND_UP, ROUND_HALF_UP

>>> x = Decimal(1.2225)
>>> x.quantize(Decimal('0.001'), ROUND_UP)
Decimal('1.223')                                 # correct
>>> y = Decimal(1.2224)
>>> y.quantize(Decimal('0.001'), ROUND_UP)
Decimal('1.223')                                 # incorrect

>>> y.quantize(Decimal('0.001'), ROUND_HALF_UP)
Decimal('1.222')                                 # correct
>>> x.quantize(Decimal('0.001'), ROUND_HALF_UP)
Decimal('1.222')                                 # incorrect

有没有办法得到想要的结果?

最佳答案

问题是 Decimal(1.2225) 不是您期望的那样:

>>> Decimal(1.2225)
Decimal('1.2224999999999999200639422269887290894985198974609375')

您正在使用浮点数来创建小数,但该浮点数对于您的用例来说已经太不精确了。如您所见,它实际上是一个 1.222499,因此它比 1.2225 小,因此可以正确舍入。

为了解决这个问题,您需要通过将它们作为字符串传递来创建具有正确精度的小数。然后一切都按预期工作:
>>> x = Decimal('1.2225')
>>> x.quantize(Decimal('0.001'), ROUND_HALF_UP)
Decimal('1.223')
>>> y = Decimal('1.2224')
>>> y.quantize(Decimal('0.001'), ROUND_HALF_UP)
Decimal('1.222')

关于python - Python 中的“正确”四舍五入到小数点后 3 位,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41020797/

10-16 22:43