Heim > Artikel > Backend-Entwicklung > Wie überprüfe ich, ob ein Float eine ganze Zahl in Python darstellt?
Bestimmen der Ganzzahl von Float-Werten
In diesem Codeausschnitt suchen Sie nach der größten Kubikwurzel, die eine ganze Zahl kleiner als ist 12.000:
processing = True n = 12000 while processing: n -= 1 if n ** (1/3) == #checks to see if this has decimals or not
Um zu überprüfen, ob ein Float-Wert eine Ganzzahl ist, können Sie Folgendes verwenden float.is_integer()-Methode:
>>> (1.0).is_integer() True >>> (1.555).is_integer() False
Beachten Sie, dass in Python 2 1/3 aufgrund der Etagendivision für ganzzahlige Operanden zu 0 führt und Gleitkomma-Arithmetik ungenau sein kann. Passen Sie die Schleife unter diesem Gesichtspunkt an:
for n in range(12000, -1, -1): if (n ** (1.0/3)).is_integer(): print n
Wir erhalten die erwarteten Ergebnisse:
27 8 1 0
Aufgrund der Ungenauigkeit der Gleitkommaarithmetik sind jedoch Zahlen größer als 3 Kubikmeter ( einschließlich 10648) entfallen. Um dieses Problem zu beheben, können Sie stattdessen nach Zahlen suchen, die nahe an der ganzen Zahl liegen:
import math for n in range(12000, -1, -1): if math.isclose((n ** (1.0/3)), round(n ** (1.0/3))): print n
Diese Variante gibt Folgendes aus:
10648 27 8 1 0
Für Python 3.5 und höher können Sie die Mathematik verwenden. Funktion isclose(), um zu prüfen, ob ein Gleitkommawert innerhalb eines anpassbaren Spielraums liegt.
Das obige ist der detaillierte Inhalt vonWie überprüfe ich, ob ein Float eine ganze Zahl in Python darstellt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!