Sie wollen ein Datum in das Format einer anderen Ländereinstellung umkonvertieren oder erhalten beim Versuch ein Datum einer Date(Time) Variable zuzuweisen die Fehlermeldung "Ungültige Konvertierung von der Zeichenfolge …… in Typ Dat.", weil das Datumsformat nicht der akutellen Ländereinstellung entspricht? Dann hilft Ihnen folgende Funktion weiter, mit der Sie ein Datum in das Format einer beliebigen Ländereinstellunge (Culture) umkonvertieren können. Um die Funktion ConvertDateTimeToCulture nutzen zu können, fügen Sie folgende Imports im Deklartionsbereich eines Moduls hinzu: Imports System.Globalization Imports System.Threading Nun nehmen Sie die Funktion auf: ''' <summary> ''' Wandelt das übergeben Datum in das Format ''' einer beliebigen Ländereinstellung um ''' </summary> ''' <param name="sDateTime">Umzuwandelte(s) Datum(Time) ''' z.B. 7/17/2006 8:51:33 AM</param> ''' <param name="NameInputCulture">Bestimmt die Culture der ''' übergebenen Variable "sDateTime" (z.B. en-US)</param> ''' <param name="NameOutputCulture">Ausgabe Culture des Datums ''' (z.B. de-DE)</param> ''' <returns></returns> ''' <remarks></remarks> Friend Function ConvertDateTimeToCulture(ByVal sDateTime As String, _ ByVal NameInputCulture As String, _ ByVal NameOutputCulture As String) As String Dim InputCulture = New System.Globalization.CultureInfo(NameInputCulture) Dim OutputtCulture As CultureInfo = _ CultureInfo.CreateSpecificCulture(NameOutputCulture) Dim oCurrentCulture As CultureInfo = _ System.Globalization.CultureInfo.CurrentCulture ' Culture des Threads entsprechend des Eingabe-Datums einstellen Thread.CurrentThread.CurrentCulture = InputCulture Dim temp As DateTime = DateTime.Parse(sDateTime, _ InputCulture, DateTimeStyles.NoCurrentDateDefault) Thread.CurrentThread.CurrentCulture = OutputtCulture ' Umgewandelte DateTime als String zurückgeben ConvertDateTimeToCulture = temp.ToString ' Culture des Threads wieder zurückstellen ' (sonst würde das Programm weiter mit der OutputCulture laufen) Thread.CurrentThread.CurrentCulture = oCurrentCulture End Function Folgendes Beispiel zeigt wie ein Datum vom Format "en-US“ in die derzeit verwendete "Culture“ umgewandelt wird: Dim sNewDateTime As DateTime sNewDateTime = ConvertDateTimeToCulture("7/17/2006 8:51:33 AM", "en-US", _ System.Globalization.CultureInfo.CurrentCulture.Name) MessageBox.Show(sNewDateTime) Falls Sie nicht gerade das Kürzel (=Name der Culture) für die gewünschte Ländereinstellung kennen, helfen Ihnen folgende Zeilen Code weiter, die alle Culturen per Debug.Print in das Direktfenster schreibt: Dim CU() As System.Globalization.CultureInfo = _ System.Globalization.CultureInfo.GetCultures( _ System.Globalization.CultureTypes.SpecificCultures) Dim CI As System.Globalization.CultureInfo ' = CultureInfo.CurrentCulture For Each CI In CU Debug.Print(CI.Name & " " & CI.DisplayName) Next CI Dieser Tipp wurde bereits 24.277 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. |
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 :-) Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
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. |