Meenzer Geschrieben 23. April 2002 Geschrieben 23. April 2002 Hallo! Ich möchte in Access eine Kommazahl ( beliebige Stellenzahl ) zu einer Ganzzahl runden. Also zum Beispiel: 248,437 = 248 aber 248,447 = 249 Hat da jemand zufällig eine Funktion oder gibt es in Access so eine Funktion schon???? Gruss Zitieren
Buell Geschrieben 23. April 2002 Geschrieben 23. April 2002 i = 248,437 i=round(i,0) Beschreibung Gibt eine Zahl zurück, die auf eine festgelegte Anzahl an Dezimalpunkten gerundet wurde. Syntax Round(Ausdruck [,AnzahlAnDezimalpunktn]) Die Syntax der Round-Funktion besteht aus folgenden Teilen: Teil Beschreibung Ausdruck Erforderlich. Numerischer Ausdruck, der gerundet wird. AnzahlAnDezimalpunkten Optional. Zahl, die angibt, wie viele Stellen rechts vom Dezimalpunkt beim Runden berücksichtigt werden. Wird dieser Wert ausgelassen, gibt die Round-Funktion Ganzzahlen zurück. (aus der Accesshilfe) mfg Buell Zitieren
Olli_Master Geschrieben 23. April 2002 Geschrieben 23. April 2002 Wenn du Access 2000 benutzt dann geht das mit der o.g. Round(..)-Funktion ganz gut. Wenn du noch die 97-er Variante hast, dann gibts diese Funktion nicht (Alternative --> CLng() ) Deine Mathematik ist ein wenig gewöhnungsbedürftig: 248,437 = 248 aber 248,447 = 249 Das ist m.E. kein Kaufmännisches bzw. mathematisches Runden. -- beim Runden wird immer nur die erste Stelle hinter der zu rundenden Ziffer betrachtet: 248,437 = 248 / 248,447 = 248 / 248,499 = 248 aber: 248,5 = 249 Ist doch logisch oder? Der Abstand von 248,447 ist doch zu 248 kleiner als zu 249 (0.447 und 0.553) Bei deiner Rechnung müsste man ja auch 248.4444445 auf 249 aufrunden :confused: Zitieren
Buell Geschrieben 23. April 2002 Geschrieben 23. April 2002 das mit dem runden geht von hinten nach vorn mfg Buelli Zitieren
Meenzer Geschrieben 24. April 2002 Autor Geschrieben 24. April 2002 Hi! Ich benutze leider die 97er Version. Naja, dann muss ich eben ne kleine Funktion schreiben Original geschrieben von Buell das mit dem runden geht von hinten nach vorn mfg Buelli Das habe ich auch gedacht. Also wie ist es jetzt mit dem Runden????????? Gruss Zitieren
beebof Geschrieben 24. April 2002 Geschrieben 24. April 2002 oder so: gerundete_zahl=int(vorherige_zahl+0,5) Zitieren
Meenzer Geschrieben 24. April 2002 Autor Geschrieben 24. April 2002 Hi! Für die jenigen, die es interessier, ich habe es jetzt so gelöst: ----------------------------------------- fktRundenGZ = Int(Zahl + 0.5) ----------------------------------------- Mit dem Runden habe ich mich erkundigt und man rundet dann nur die erste Stelle hinter dem Komma. Also ich addiere 0,5 zu der Zahl dazu und schneide mit der INT-Funktion die Kommastellen ab. Damit ist die Zahl gerundet. Gruss Zitieren
Hammerhead Geschrieben 15. Mai 2002 Geschrieben 15. Mai 2002 du musst einfach die variable, die du runden willst als integer deklarieren. Nachkomma Runden: VB Funktionen: int ((date()-geburt)/365.25); oder format ((date()-geburt)/365.25, "0.00") in diesem Beispiel geht es um das ausrechnen eines alters. also geburtdatum - heutiges datum / 365.25 (.25 wegen schaltjahre) und das "0.00" gibt die nachkomma stellen an. wenn du "0.0" machst hast halt nur eine ! wenn du das erste nimmst, dann kümmert sich das int um das runden ! Zitieren
Hammerhead Geschrieben 15. Mai 2002 Geschrieben 15. Mai 2002 Sorry Jungs, hab das ganze nochmal berprüft. Das shit Microsoft Access rundet grundsätzlich ab ! Check jetzt auch was du mit "aber " gemeint hast. *lol* Also vergessts den Post drüber. Aber vielleicht hilft er ja doch jemanden, den das runden interressiert. Noch was, wenn man beim Teilen statt dem / nen \ nimmt, dann rundet der auch schon ! Hammerhead visit www.germanfragforce.de Zitieren
fireworker Geschrieben 15. Mai 2002 Geschrieben 15. Mai 2002 wie wäre es mit Obergrenze und Untergrenze? Die runden auf die jeweiligen Stellen hinter dem Komma, welche Du angibst und vor allem kannst Du noch Schrittweite angeben. Viel Spaß beim Testen. Zitieren
Olli_Master Geschrieben 16. Mai 2002 Geschrieben 16. Mai 2002 Bei dem Post waren einige Aussagen dabei, die nicht ganz korrekt sind. Damit es später keine Verwirrungen gibt, hier nochmal eine Zusammenfassung: Beim Runden muss stets die Genauigkeit angegeben werden, auf die gerundert werden soll (z.B. 1/10 oder 1/100). Ziel des Rundens ist es, die Zahl y mit der angegebenen Genauigkeit zu finden, die am nächsten zur ursprünglichen Zahl x liegt. y = f(x) Es ging hier zunächst um das Runden von Dezimalzahlen zu ganzen Zahlen: Dafür stehen unter MS Access verschiedene Funktionen zur Verfügung: 1. Int(zahl + 0,5) 2. Round(zahl) 3. CLng(zahl) Variante 1 funktioniert in allen Access-Versionen und bietet sich auch an um auf eine andere Genauigkeit zu runden (z.B. 1/100 => fGerundet=Int([zahl]*100+0,5)/100 ) Variante 2 funktioniert ab Access 2000 Variante 3 ist etwas problematisch. Laut Online-Hilfe (Access 97) werden Nachkommastellen gerundet. Dies klappt aber nicht immer korrekt (CLng(22,5) ergibt 22). Diese Funktion sollte man daher vermeiden. -------------------------------------------------------------------------- Außerdem wurde mehrfach gesagt dass Zahlen von hinten nach vorn zu runden sind. Meines Wissens nach ist das nicht richtig. Ausschlaggebend für die Rundung ist nur die jeweils 1. Ziffer hinter der zu rundenden Stelle. z.B. Rundung 1/100: x = 12.244 >> y = 12,24 x = 12,2444 >> y = 12,24 x = 12,2445 >> y = 12,25 x = 12.245 >> y = 12,25 (betrachtet wird hier nur die dritte Ziffer hinter dem Komma!!!) -------------------------------------------------------------------------- Sollte trotzdem jemand anderer Meinung sein, wäre ein Nachweis nicht schlecht. Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.