| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |

05-05-2011, 12:16
|
|
phop
Registrierter Benutzer
|
|
Registriert seit: Apr 2011
Beiträge: 8
|
|
Potenz in die entsprechende Ganzzahl umwandeln PHP
Ich habe eine Potenz z.B 7.61086E+12 die ich gerne in die entsprechende Ganzzahl umwandeln möchte?
Vielleicht kann mir jemand einen Rat geben, wäre sehr Dankbar!
|

05-05-2011, 12:26
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Hallo,
number_format() macht sowas.
Gruß,
Amica
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

05-05-2011, 16:09
|
|
mephisto111
Registrierter Benutzer
|
|
Registriert seit: Nov 2003
Beiträge: 41
|
|
Alternative
Für eine formatierte Ausgabe ist Amicas Vorschlag ideal. Sonst bietet sich auch ein Cast an:
PHP-Code:
<?php
echo (int)7.61086E+12;
?>
|

05-05-2011, 16:20
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Aber aufpassen beim Casten! Da muss man vorher wissen, ob es im Wertebereich von int liegt:
PHP-Code:
echo number_format(987.654e32); // 98,765,400,000,000,000,344,474,795,032,707,072
var_dump((int) 987.654e32); // int(0)
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

07-05-2011, 14:51
|
 |
fireweasel
Registrierter Benutzer
|
|
Registriert seit: Sep 2008
Ort: At home
Beiträge: 680
|
|
Zitat:
Zitat von mephisto111
Für eine formatierte Ausgabe ist Amicas Vorschlag ideal. Sonst bietet sich auch ein Cast an:
PHP-Code:
<?php
echo (int)7.61086E+12;
?>
|
Das macht Schwierigkeiten, wenn
Code:
abs($number) > PHP_INT_MAX
ist.
Falls es nur um den Ganzzahl-Anteil geht, dafür sind floor(), ceil() oder round(..., 0) zuständig.
__________________
PHP-Code:
class Brick implements Throwable {
// ...
}
Geändert von fireweasel (07-05-2011 um 14:54 Uhr)
|

07-05-2011, 20:25
|
|
mephisto111
Registrierter Benutzer
|
|
Registriert seit: Nov 2003
Beiträge: 41
|
|
@AmicaNoctis
Der eigentlich interessante Punkt Deiner Replik ist die Tatsache, dass PHP sehr große Fließkommazahlen beim Casten nach Int ohne Überlaufmeldung stillschweigend auf 0 setzt. Vielleicht sollte man noch erwähnen, dass "numberformat" einen String (und keinen Integer) zurückliefert.
@fireweasel
"floor", "ceil" und "round" haben wieder Fließkommazahlen als Rückgabewerte. Ausgangspunkt war die (nicht ganz eindeutige) Frage nach der Umwandlung der Fließkommadarstellung einer ganzen Zahl, nämlich 7.61086E+12, in die entsprechende Ganzzahl. Es ging also nicht um Auf- oder Abrunden.
Die Information, dass man (standardmäßig) z.B. bei einem 64-Bit-System unter Berücksichtigung des Vorzeichens nur noch 63 Bit für die eigentliche Zahl zur Verfügung hat, hat mich nicht so besonders überrascht.
|

07-05-2011, 22:32
|
AmicaNoctis
 Moderatorin
|
|
Registriert seit: Jul 2009
Beiträge: 5.550
|
|
Zitat:
Zitat von mephisto111
Vielleicht sollte man noch erwähnen, dass "numberformat" einen String (und keinen Integer) zurückliefert.
|
Okay, das habe ich nicht erwähnt, weil ich es für logisch hielt. Wäre der Rückgabewert ein Integer, wäre er bei großen Zahlen wieder 0, weil es wieder nicht in den Wertebereich passt.
__________________
Hast du die Grundlagen zur Fehlersuche gelesen? Hast du Code-Tags benutzt? 
Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
Super, danke! 
|

11-05-2011, 10:51
|
 |
fireweasel
Registrierter Benutzer
|
|
Registriert seit: Sep 2008
Ort: At home
Beiträge: 680
|
|
Zitat:
Zitat von mephisto111
@fireweasel
"floor", "ceil" und "round" haben wieder Fließkommazahlen als Rückgabewerte.
|
Genau, deswegen schrob ich "Ganzzahl-Anteil". Und ein Blick ins Handbuch macht schnell klar, welchen Datentyp der Rückgabewert annehmen kann. Sowas sollte man nicht immer extra erwähnen müssen.
Zitat:
|
Ausgangspunkt war die (nicht ganz eindeutige) Frage nach der Umwandlung der Fließkommadarstellung einer ganzen Zahl, nämlich 7.61086E+12, in die entsprechende Ganzzahl.
|
Wegen der Nicht-ganz-Eindeutigkeit hatte ich diese Funktionen erwähnt. Andernfalls hätte ich mich zurückgehalten, weil mir der Wertebereich, in dem number_format() funktioniert, vollkommen ausgereicht hätte. Integer-Casts oder intval() hatte ich als bekannt vorausgesetzt.
Zitat:
|
Es ging also nicht um Auf- oder Abrunden.
|
Ein Integer-Cast "rundet" auch erst, bevor der Typ konvertiert wird.
Zitat:
|
Die Information, dass man (standardmäßig) z.B. bei einem 64-Bit-System unter Berücksichtigung des Vorzeichens nur noch 63 Bit für die eigentliche Zahl zur Verfügung hat, hat mich nicht so besonders überrascht.
|
Dich nicht, aber den OP möglicherweise und auf 32-Bit-Integer-Systemen (die dürften bei PHP derzeit noch Standard sein) ist diese Grenze noch schneller erreicht.
__________________
PHP-Code:
class Brick implements Throwable {
// ...
}
|

11-05-2011, 14:22
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.486
|
|
Zitat:
Zitat von fireweasel
Ein Integer-Cast "rundet" auch erst, bevor der Typ konvertiert wird.
|
Nein, macht er nicht (auch wenn du es in Anführungszeichen geschrieben hast) - der schneidet die Nachkommastellen einfach ab.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|

11-05-2011, 22:14
|
 |
fireweasel
Registrierter Benutzer
|
|
Registriert seit: Sep 2008
Ort: At home
Beiträge: 680
|
|
Zitat:
Zitat von wahsaga
Nein, macht er nicht ...
|
*update*
Doch, macht er.  Intval() oder (int) auf Gleitkommazahlen angewandt, führen in PHP über ein paar Umwege zum Aufruf eines (oder mehrerer) C-Typecasts[1]. Die dabei prinzipiell verwendbaren vier möglichen Rundungs-Arten wären "round down" (floor), "round up" (ceil), "round to nearest" (deine mathematische Rundung) und "round towards zero" (truncate). Ein C-Compiler, der sich an den ANSI-Standard hält, muss letzteres benutzen.
Zitat:
Zitat von wahsaga
... (auch wenn du es in Anführungszeichen geschrieben hast) - der schneidet die Nachkommastellen einfach ab.
|
Für diesen Datentyp ist "Abschneiden der Nachkommastellen" eine der vier möglichen Formen des Rundens, wenn auch eine für Mathematiker eventuell nicht so gängige. Deswegen hatte ich die Anführungszeichen gesetzt. Sie sollten eigentlich die Diskussion "echtes Runden vs. Abschneiden" vermeiden helfen.
[1] Falls das irgendwen interessiert: Zend/zend_operators.h definiert je nach Systemumgebung ein Macro oder eine Funktion namens zend_dval_to_lval(), welche(s) die Double-To-Integer-Casts ausführt.
*originale Antwort (11. 05. 2011, 22:14)*
Zeigst du mir bitte die Stelle im Quellcode, wo das so gemacht wird? Ich finde aufgrund planlosen Herumsuchens nichts.
Bis dahin verweise ich auf den Abschnitt Typumwandlung von Integer nach Float im Handbuch, wo neben anderen (wichtigen) Hinweisen das "Runden" ohne Anführungszeichen benutzt wird:
Zitat:
|
When converting from float to integer, the number will be rounded towards zero.
|
Wobei man sich natürlich jetzt streiten kann, ob es wirklich einen Unterschied zwischen "Runden zur nächsten Ganzzahl in Richtung Null" oder "Abschneiden der Nachkommastellen" gibt ...
__________________
PHP-Code:
class Brick implements Throwable {
// ...
}
Geändert von fireweasel (12-05-2011 um 12:50 Uhr)
|

11-05-2011, 22:51
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.486
|
|
Zitat:
Zitat von fireweasel
Wobei man sich natürlich jetzt streiten kann, ob es wirklich einen Unterschied zwischen "Runden zur nächsten Ganzzahl in Richtung Null" oder "Abschneiden der Nachkommastellen" gibt ... 
|
Eben, Unterschied nichtexistent.
Unter „Runden“ verstehe ich aber das im mathematischen Sinne.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|