VB 2005 bietet zwar die Math.Round-Funktion an, die allerdings nur für Werte mit Nachkommastellen verwendbar ist. Folgende Funktion rundet "Ganzzahlen" (alle Integertypen in VB) nach beliebiger Stellenzahl, alternativ nach den gleichen Methoden, wie bei Math.Round (MidpointRounding.AwayFromZero oder MidpointRounding.ToEven). Der Code ist, denke ich, selbsterklärend: ' Runden von Ganzzahlen ' ganzZahl- die Zahl (Integer, Long) ' anzRst- Anzahl der Stellen von rechts, nach denen gerundet werden soll ' mode- der Modus der Rundung Public Function Runden(ByVal ganzZahl As Object, _ Optional ByVal anzRst As Integer = 1, _ Optional ByVal mode As MidpointRounding = MidpointRounding.AwayFromZero) Dim typeCode As TypeCode = Type.GetTypeCode(ganzZahl.GetType()) Dim divRest As New TypeCode ' Bestimmung des Zahlentyps Dim gTyp As String = TypeName(ganzZahl) ' Prüfen, ob Anzahl Rundungsstellen >= Anzahl der Stellen von ganzZahl Dim anzSt As Short = CStr(ganzZahl).Length If anzRst >= anzSt Then gTyp = "" ' Originalwert wird zurück gegeben Select Case gTyp Case "Short", "Integer", "Long", "UShort", "UInteger", "ULong" Dim zehnPotenz As Short = 10 ^ anzRst Dim rundWert As Short = 5 * 10 ^ (anzRst - 1) Dim dezKonst As Short = 0 divRest = ganzZahl Mod zehnPotenz If mode = MidpointRounding.AwayFromZero Then If divRest > rundWert Then dezKonst = zehnPotenz - divRest ElseIf divRest < rundWert Then dezKonst = -divRest End If Else dezKonst = -divRest End If Return ganzZahl + dezKonst Case Else Return ganzZahl End Select End Function Dieser Tipp wurde bereits 14.912 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. Neu! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |