Python float round error 117.285 round to 117.28 not 117.29

后端 未结 3 1678
爱一瞬间的悲伤
爱一瞬间的悲伤 2020-12-10 17:47

I am using python 2.7, and the code I have is:

a = 10.5 * 22.34 / 2.0
print \"%.2f\" % a

and the result I expect is 117.29, but it shows 11

相关标签:
3条回答
  • 2020-12-10 18:20

    If Python is using a 64-bit IEEE-754 binary floating point type, then the exact value it's using will be

    117.284999999999996589394868351519107818603515625
    

    ... and that's obviously lower than the midpoint between 117.28 and 117.29. It's possible that that's what's going on.

    Another option is that Python is using Banker's Rounding.

    If the exact decimal values matter to you, you might want to consider using decimal instead.

    0 讨论(0)
  • 2020-12-10 18:32

    If you want a simple solution and don't care about performance, you could use a function like this to convert to integer, round, and convert back to float:

    def round_exact(number, decimal_places=0):
        """Round the number to the given number of decimal places by converting to 
        and from integers to avoid floating point error."""
        factor = 10**(decimal_places + 1)
        rounded_int = int(number * factor)
        if rounded_int % 10 >= 5:
            # Round up
            return (int(rounded_int//10) + 1) / float(factor//10)
        # Round down
        return int(rounded_int//10) / float(factor//10)
    
    0 讨论(0)
  • 2020-12-10 18:43

    Mr. Skeet has the correct answer, below is an example of how to use the decimal module to which he refers:

    import decimal
    a = decimal.Decimal('117.285')
    rounded = a.quantize(decimal.Decimal('.01'), rounding=decimal.ROUND_HALF_UP)
    print rounded
    # 117.29
    repr(rounded)
    # "Decimal('117.29')"
    
    0 讨论(0)
提交回复
热议问题