Rubrik: Datum/Zeit und Timer · Datums- und Zeit-Funktionen | VB-Versionen: VB.NET | 21.08.06 |
Date(Time) ins Format einer anderen Ländereinstellung umwandeln (VB.NET) Hier wird gezeigt, wie sich ein Datum (Uhrzeit) in das Format einer anderen Ländereinstellung umwandeln lässt. | ||
Autor: Carsten Stuplich | Bewertung: | Views: 24.203 |
ohne Homepage | System: WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
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