我有两个整数值a和b,但我需要它们在浮点数中的比值。我知道a < b,我想计算a / b,所以如果我用整数除法,我总是得到0,余数是a。

如何在以下Python 2中强制c为浮点数?

c = a / b

在3。X,行为是相反的;参见为什么整数除法产生一个浮点数而不是另一个整数?反之为3。x-specific问题。


当前回答

如何在Python中强制除法为浮点数? 我有两个整数值a和b,但我需要它们在浮点数中的比值。我知道a < b,我想计算a/b,所以如果我用整数除法,我总是得到0,余数是a。 如何在下面的Python中强制c为浮点数? C = a / b

这里真正被问到的是:

"如何强制真除法使a / b返回一个分数"

升级至python3

在python3中,要得到真正的除法,只需执行a / b。

>>> 1/2
0.5

整数的经典除法现在是a // b:

>>> 1//2
0
>>> 1//2.0
0.0

然而,你可能会被困在使用python2中,或者你可能正在编写必须在python2和python3中工作的代码。

如果使用Python 2

在Python 2中,没有这么简单。处理经典Python 2除法的一些方法比其他方法更好、更健壮。

Python 2推荐

你可以在任何给定的模块中通过下面的导入来获得Python 3除法行为:

from __future__ import division

然后将Python 3样式的除法应用于整个模块。它在python shell中也可以在任何给定的点上工作。在Python 2中:

>>> from __future__ import division
>>> 1/2
0.5
>>> 1//2
0
>>> 1//2.0
0.0

这确实是最好的解决方案,因为它可以确保模块中的代码与Python 3更加兼容。

Python的其他选项

如果您不想将此应用于整个模块,则只能使用一些变通方法。最流行的方法是将其中一个操作数强制为浮点数。一个健壮的解决方案是a / (b * 1.0)。在一个新的Python shell中:

>>> 1/(2 * 1.0)
0.5

同样鲁棒的是来自operator模块operator的truediv。Truediv (a, b),但这可能更慢,因为它是一个函数调用:

>>> from operator import truediv
>>> truediv(1, 2)
0.5

Python 2不推荐使用

常见的是a / float(b)。如果b是一个复数,这将引发TypeError。因为定义了复数除法,所以当除法被传递一个复数作为除数时,它不会失败,这对我来说是有意义的。

>>> 1 / float(2)
0.5
>>> 1 / float(2j)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: can't convert complex to float

对我来说,故意让代码变得更脆弱没有多大意义。

你也可以使用-Qnew标志运行Python,但这有一个缺点,即使用新的Python 3行为执行所有模块,并且某些模块可能需要经典除法,所以我不建议这样做,除非用于测试。但是为了证明:

$ python -Qnew -c 'print 1/2'
0.5
$ python -Qnew -c 'print 1/2j'
-0.5j

其他回答

在Python 3中。X,单斜杠(/)总是表示真(非截断)除法。(//运算符用于截断除法。)在Python 2中。X(2.2及以上),您可以通过放置一个

from __future__ import division

在模块的顶部。

这个也可以

>>> u=1./5
>>> print u
0.2

在python2中,两个整型的除法得到一个整型。在Python 3中,它产生一个浮点数。我们可以通过从__future__导入来获得新的行为。

>>> from __future__ import division
>>> a = 4
>>> b = 6
>>> c = a / b
>>> c
0.66666666666666663

如果你想默认使用"true"(浮点)除法,有一个命令行标志:

python -Q new foo.py

这里有一些缺点(来自PEP):

有人认为,命令行选项可以更改 违约是邪恶的。如果做错了,肯定会很危险 手:举个例子,不可能组合第三个手 需要-Qnew的party库包与另一个 需要-Qold。

通过查看python手册页,您可以了解更多关于更改/警告除法行为的其他标志值。

有关除法更改的详细信息,请参阅:PEP 238—更改除法操作符

只要将任何用于除法的参数设置为浮点格式,也会产生浮点格式的输出。

例子:

>>> 4.0/3
1.3333333333333333

or,

>>> 4 / 3.0
1.3333333333333333

or,

>>> 4 / float(3)
1.3333333333333333

or,

>>> float(4) / 3
1.3333333333333333