Aby sprawdzić, czy liczba zmiennoprzecinkowa jest liczbą całkowitą, użyj float.is_integer()
metody :
>>> (1.0).is_integer()
True
>>> (1.555).is_integer()
False
Metodę dodano do float
typu w Pythonie 2.6.
Weź pod uwagę, że w Pythonie 2 1/3
jest 0
(dzielenie podłogi dla argumentów całkowitych!), A arytmetyka zmiennoprzecinkowa może być nieprecyzyjna (a float
jest przybliżeniem przy użyciu ułamków binarnych, a nie dokładną liczbą rzeczywistą). Ale nieznaczne dostosowanie pętli daje:
>>> for n in range(12000, -1, -1):
... if (n ** (1.0/3)).is_integer():
... print n
...
27
8
1
0
co oznacza, że cokolwiek powyżej 3 kostek (w tym 10648) zostało pominięte z powodu wyżej wspomnianej niedokładności:
>>> (4**3) ** (1.0/3)
3.9999999999999996
>>> 10648 ** (1.0/3)
21.999999999999996
Zamiast tego musisz sprawdzić liczby zbliżone do całego numeru lub nie użyć go float()
do znalezienia swojego numeru. Jak zaokrąglenie w dół pierwiastka z 12000
:
>>> int(12000 ** (1.0/3))
22
>>> 22 ** 3
10648
Jeśli używasz języka Python 3.5 lub nowszego, możesz użyć tej math.isclose()
funkcji, aby sprawdzić, czy wartość zmiennoprzecinkowa mieści się w konfigurowalnym marginesie:
>>> from math import isclose
>>> isclose((4**3) ** (1.0/3), 4)
True
>>> isclose(10648 ** (1.0/3), 22)
True
W starszych wersjach naiwna implementacja tej funkcji (pomijanie sprawdzania błędów i ignorowanie nieskończoności i NaN), jak wspomniano w PEP485 :
def isclose(a, b, rel_tol=1e-9, abs_tol=0.0):
return abs(a - b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)