开发者

python round problem

I am facing the problem while dividing

my max_sum = 14
total_no=4  

开发者_Go百科so when i do

print "x :", (total_sum/total_no)

, I get 3 and not 3.5

I tried many ways for printing but failed, can somebody let me know what way I get in 3.5 format?

Thank you


In Python 2.x, dividing two integers by default dives you another integer. This is often confusing, and has been fixed in Python 3.x. You can bypass it by casting one of the numbers to a float, which will automatically cast the other:

float( 14 ) / 4 == 3.5

The relevant PEP is number 238:

The current division (/) operator has an ambiguous meaning for numerical arguments: it returns the floor of the mathematical result of division if the arguments are ints or longs, but it returns a reasonable approximation of the division result if the arguments are floats or complex. This makes expressions expecting float or complex results error-prone when integers are not expected but possible as inputs.

It was not changed in Python 2.x because of severe backwards-compatibility issues, but was one of the major changes in Python 3.x. You can force the new division with the line

from __future__ import division

at the top of your Python script. This is a __future__-import -- it is used to force syntax changes that otherwise might break your script. There are many other __future__ imports; they are often a good idea to use in preparation for a move to Python 3.x.

Note that the // operator always means integer division; if you really want this behaviour, you should use it in preference to /. Remember, "explicit is better than implicit"!


You are dividing two integers, the result will be an integer too, in python 2. Try make one of your operands a float, like max_sum = 14.0 or total_no = 4.0 to get a float result.

If you want python 2.X behave a bit more intuitive in that matter you can add

from __future__ import division

on the top of your script. In python 3, division works as you expected it in your case.


make max_sum=14.0 or total_no=4.0


You're doing an integer operation so you get the nearest integer result : 3.

You should either explicitly/implicitly cast max_sum or total to float.


Another way of doing this would be to import division from Python 3:

>>> from __future__ import division
>>> max_sum = 14
>>> total_no = 4
>>> print max_sum / total_no  # the way you want it
3.5
>>> print max_sum // total_no
3
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜