本篇文章,想聊一下Python中的round()方法。
 这时候,有人就会说,round()方法嘛!简单!round() 方法就是返回浮点数x的四舍五入值。
你看下面这些例子:
round(100.123,1)
round(-100.1)
round(80.23456,3)
round(1.75,1) 
上面的运行结果:
100.1
-100
80.235
1.8 
一切正常,返回浮点数的四舍五入呀。
 那么你再看下面的例子:
round(1.25,1)
round(1.65,1) 
运行结果:
1.2
1.6 
大家可以试试看!!
 嗯??为啥不是1.3和1.7嘞?不是四舍五入的吗?且听我分析~~
在python2中,round()方法确实是 “四舍” ,却不是 “五入”。如果两端一样远,也就是碰到 “5” 时,则保留距离0远的一边。大于 “5” 的数,才 “入”。
 而在python3中,round()方法也是 “四舍”,如果两端一样远,会保留到偶数一边。大于 “5” 的数才“入”。这也就是为什么上面的例子是1.2和1.6了。(本人在Python3中运行的)
 原来如此,round()方法还分情况讨论的呀
 这就完了吗?并没有!再看下面的例子:
round(2.675,2) 
运行结果:
2.67 
到这儿,小伙伴们就纳闷了,为啥?
 无论在Python2中还是Python3中,得到的结果都应该是 “2.68”,可这里的结果为什么是 “2.67”?
 莫慌~~
 在机器中浮点数不一定能精确表达,机器做出了截断处理。那么在机器中保存的2.675这个数字就比实际数字要小那么一点点。这一点点就导致了它离2.67要更近一点点,所以保留两位小数时就近似到了2.67。
 不好理解?看下图:
 Decimal类型可以非常精确地在计算机中存储,我们导入该模块,查看“2.675”
 
 在存储时,确实小那么一点点,所以保留两位小数时,成了“2.67”。
 总结
 看来,round()方法并不只是简单的四舍五入,不仅要分Python2和Python3讨论,还要看数字在计算机中的存储!!确实值得好好研究。
