Mit nachfolgender Funktion lässt sich das im System eingestellte Zahlen- und Währungsformat (Tausender- und Dezimaltrennzeichen) neu festlegen - entweder für den aktuell angemeldeten Benutzer oder auf Wunsch auch auf alle Benutzer. ' benötigte API-Deklarationen Private Declare Function GetSystemDefaultLCID Lib "kernel32" () As Long Private Declare Function GetUserDefaultLCID Lib "kernel32" () As Long Private Declare Function SetLocaleInfo Lib "kernel32" _ Alias "SetLocaleInfoA" ( _ ByVal Locale As Long, _ ByVal LCType As Long, _ ByVal lpLCData As String) As Long Private Declare Function PostMessage Lib "user32" _ Alias "PostMessageA" ( _ ByVal hWnd As Long, _ ByVal wMsg As Long, _ ByVal wParam As Long, _ ByVal lParam As Long) As Long Private Const LOCALE_SMONDECIMALSEP = &H16 Private Const LOCALE_SDECIMAL = &HE Private Const LOCALE_SMONTHOUSANDSEP = &H17 Private Const LOCALE_STHOUSAND = &HF Private Const WM_SETTINGCHANGE = &H1A Private Const HWND_BROADCAST = &HFFFF& Public Function SetNewNumberFormat(ByVal sDecChar As String, _ Optional ByVal sGroupChar As String = "", _ Optional ByVal bAllUser As Boolean = True) As Boolean Dim nLCID As Long Dim bResult As Boolean If bAllUser Then ' systemweite Änderung für alle Benutzer nLCID = GetSystemDefaultLCID() Else ' Änderung nur für den aktuell angemeldeten Benutzer nLCID = GetUserDefaultLCID() End If ' Neues Währungsformat setzen bResult = (SetLocaleInfo(nLCID, LOCALE_SMONDECIMALSEP, sDecChar) <> 0) bResult = (SetLocaleInfo(nLCID, LOCALE_SMONTHOUSANDSEP, sGroupChar) <> 0) ' Neues Zahlenformat setzen bResult = (SetLocaleInfo(nLCID, LOCALE_SDECIMAL, sDecChar) <> 0) bResult = (SetLocaleInfo(nLCID, LOCALE_STHOUSAND, sGroupChar) <> 0) If bResult Then ' System über die Änderung benachrichtigen PostMessage HWND_BROADCAST, WM_SETTINGCHANGE, 0, 0 End If SetNewNumberFormat = bResult End Function Beispielaufruf: ' Punkt als Tausenderzeichen, und Komma als Dezimalzeichen ' für den aktuellen Benutzer festlegen If SetNewNumberFormat(",", ".", False) Then MsgBox "Zahlen- und Währungsformat wurden korrekt umgestellt" Else MsgBox "Systemeinstellungen konnten nicht geändert werden." & vbCrLf & _ "Ggf. hat der angemeldete Benutzer nicht genügend Rechte!" End If Dieser Tipp wurde bereits 16.971 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 (einschl. Beispielprojekt!) 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. sevWizard für VB5/6 Professionelle Assistenten im Handumdrehen Erstellen Sie eigene Assistenten (Wizards) im Look & Feel von Windows 2000/XP - mit allem Komfort und zwar in Windeseile :-) |
||||||||||||||||
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. |