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.623 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. |
sevISDN 1.0 Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. Tipp des Monats Januar 2025 Dieter Otter Zeilen einer MultiLine-TextBox ermitteln (VB.NET) Dieser Zipp zeigt, wie man die Zeilen einer MultiLine-TextBox exakt so ermitteln kann, wie diese auch in der TextBox dargestellt werden. TOP! Unser Nr. 1 Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. |
||||||||||||||||
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. |