vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#

https://www.vbarchiv.net
Rubrik: Datum/Zeit und Timer · Datums- und Zeit-Funktionen   |   VB-Versionen: VB.NET21.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 StuplichBewertung:  Views:  24.203 
ohne HomepageSystem:  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



Anzeige

Kauftipp Unser Dauerbrenner!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.
 
 
Copyright ©2000-2024 vb@rchiv Dieter OtterAlle Rechte vorbehalten.


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.