round() 似乎没有正确舍入

round() doesn#39;t seem to be rounding properly(round() 似乎没有正确舍入)
本文介绍了round() 似乎没有正确舍入的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

round() 函数的文档说明您通过它是一个数字,小数点后的位置要四舍五入.因此它应该这样做:

The documentation for the round() function states that you pass it a number, and the positions past the decimal to round. Thus it should do this:

n = 5.59
round(n, 1) # 5.6

但是,实际上,旧的浮点怪异现象逐渐出现,您会得到:

But, in actuality, good old floating point weirdness creeps in and you get:

5.5999999999999996

出于 UI 的目的,我需要显示 5.6.我在互联网上一探究竟,发现了一些 文档取决于我对 Python 的实现.不幸的是,这发生在我的 Windows 开发机器和我尝试过的每台 Linux 服务器上.另见此处.

For the purposes of UI, I need to display 5.6. I poked around the Internet and found some documentation that this is dependent on my implementation of Python. Unfortunately, this occurs on both my Windows dev machine and each Linux server I've tried. See here also.

没有创建自己的圆形库,有什么办法解决这个问题吗?

Short of creating my own round library, is there any way around this?

推荐答案

我无法控制它的存储方式,但至少格式可以正常工作:

I can't help the way it's stored, but at least formatting works correctly:

'%.1f' % round(n, 1) # Gives you '5.6'

这篇关于round() 似乎没有正确舍入的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)