【Python 基础教程】彻底解决python round函数的四舍五入不精确的问题

本文探讨了Python中小数的不精确性,如相加时的精度丢失和round函数的四舍五入误差。通过示例展示了round函数在处理小数时可能出现的问题,并提出了解决方案,即通过扩大数值来获得精确的四舍五入结果。此外,还介绍了Decimal模块,用于实现精确的浮点数运算,包括如何创建Decimal对象和进行精确四舍五入的方法。
摘要由CSDN通过智能技术生成


前言🥦

在Python官方有这样一句话:The behavior of round() for floats can be surprising: for example, round(2.675, 2) gives 2.67 instead of the expected 2.68. This is not a bug: it’s a result of the fact that most decimal fractions can’t be represented exactly as a float. See Floating Point Arithmetic: Issues and Limitations for more information也就是说,在Python语言中小数的存储往往是近似值,并不像整数那样精确。我们呢有时候需求就是对小数的指定位数进行四舍五入,今天博主在这里分享一下在Python中进行小数四舍五入的几种方法。如果你也有什么好的方法欢迎评论区留言哦。


一、小数不精确的常见问题🥦

Python中的小数存储往往是不精确的,相加的时候可能会导致精度丢失,或者结果出乎意料。

1.相加🌴

print(1.01+1.02)
在这里插入图片描述

2.四舍五入🌴

以下代码的打印结果
print(round(1.135,2))
print(round(1.235,2))
print(round(1.335,2))
print(round(1.435,2))
print(round(1.535,2))
print(round(1.635,2))
最后的一位数应该都为4,但是由于精度丢失,导致有些数四舍五入失败。
在这里插入图片描述

二、round函数🥦

1.简介🌴

官方给出的接口如下:

def round(number: SupportsRound[_T], ndigits: SupportsIndex)

第一个参数指的是需要进行四舍五入的小数,第二个参数是保留的小数位
默认是保留0位小数,也就是保留到整数。

2.使用方法🌴

① 代码🌵:

print(round(1.135,2))
print(round(1.235,2))
print(round(1.335,2))
print(round(1.435,2))
print(round(1.535,2))
print(round(1.635,2))

② 运行结果🌵:

在这里插入图片描述

③ 暴露问题🌵:

可以看出来运行结果不是很理想,因为有些数值四舍五入进位失败,我们可以处理一下,然后就可以得到准确的结果了。经过分析当只有一位小数的时候保留到整数,进位比较准确。
代码:
在这里插入图片描述
结果:
在这里插入图片描述

④ 解决方法🌵:

我们可以对代码做出这样的改动,也就是利用四舍五入一位小数可以获得精确值的性质
可以先将数值扩大n倍,直到将保留小数位的下一位小数提到小数部分第一位,也就是说保留两位小数就将第三位小数提到第一位,做的操作就是乘以100。依次类推

print(round(1.235,2))
print(round(1.3355*100)/100)
print(round(1.435,2))
print(round(1.5355*100)/100)
print(round(1.635,2))

在这里插入图片描述

三、Decimal模块🥦

这是一个精确小数计算的模块,咱们只在这里说一下他的简单使用方法。


1.创建Decimal小数🌴

① 字符串型🌵

代码:

print("Decimal精确的1.35:",Decimal("1.35"))

运行结果:
在这里插入图片描述

② 数值型🌵

代码:

print("float型的1.35",Decimal(1.35))

运行结果:
在这里插入图片描述

2.结合round函数精确四舍五入🌴

代码:

from decimal import Decimal
print(round(Decimal("1.535"),2))
print(round(Decimal("1.335"),2))

运行结果:
在这里插入图片描述

3.使用自身方法精确四舍五入🌴

代码:

print(Decimal("1.3355").quantize(Decimal("0.000")))
print(Decimal("1.2955").quantize(Decimal("0.00")))
print(Decimal("1.3355").quantize(Decimal("0.00")))

运行结果:
在这里插入图片描述

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酷尔。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值