Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

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

Geschrieben

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

Geschrieben

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:

Geschrieben

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

Geschrieben

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

  • 3 Wochen später...
Geschrieben

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 !

Geschrieben

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

Geschrieben

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.

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.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung wiederherstellen

  Nur 75 Emojis sind erlaubt.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...