1.想必round()很熟悉吧 (四舍六入五成双精确)
round()取精度类似于大学实验报告里的取精度, 奇进偶舍,因为四舍五入满五就进一最后实验结果会偏高。
所以这里的round()实际上并不是四舍五入取精度,具体是下面这个样子。
譬如,你要对于a.bcd取精度,精确位数是2,那么就是精确到c位置。(可以看官方文档最好,里面有详细介绍)
如果d小于5,直接舍去。
如果d大于5,直接进一。
如果d等于5,分三种情况:
1.如果d后面没有数字,且c为奇数,那么进一,即(c + 1)
2.如果d后面没有数字,且c为偶数,那么不进位, 即(c)
3.如果d后面还有数字,那么进一,即(c + 1)
最后,还要说一下,如果round()给出的精确数值和上面本应得出的精确数值不同,那么要考虑一下你给round的值是不是精确的,因为实际上python保留小数有时候是不精确的,譬如
对于1.235实际保存的是下面这个样子。
2.math模块的ceil(向上取整),floor (向下取整)
这个没什么好说;
3. decimal模块真正的四舍五入
这个四舍五入就是和我们日常生活,学习中了解到的那个样子。
能看官方文档最好。
rounding = ROUND_HALF_UP表示这个按四舍五入精确;Decimal('1.')表示精确小数点后0位,当然,Decimal('1.0')——>小数点后一位,Decimal('1.00')——>小数点后两位。
4.其实有更简单的四舍五入,唉
上面这个deciaml模块太过于强大,杀鸡焉用宰牛刀
1. num = 1.5 2. num = int(num + 0.5)
就这个样子就可以了,假使你只需要四舍五入这一个方法去解决某些问题的话。