Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Kommazahl aufrunden

Empfohlene Antworten

Veröffentlicht

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

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

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:

das mit dem runden geht von hinten nach vorn

mfg

Buelli

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

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...

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 !

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

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.

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.

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.