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

https://www.vbarchiv.net
Rubrik: Datum/Zeit und Timer · Datums- und Zeitfunktionen   |   VB-Versionen: VB4, VB5, VB605.07.04
Zeitdifferenz zur GMT-Zeitangabe ermitteln

Ermittelt die Zeitdifferenz in Stunden zwischen GM-Time und Local-Time

Autor:   Ralf DuchnaBewertung:  Views:  18.551 
ohne HomepageSystem:  Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Sicherlich haben Sie schon einmal folgende Zeitangabe gesehen: 08:45 +02:00
Hierbei wird der Ortszeit die Zeit-Differenz zur GMT-Zeitangabe nachgestellt. Je nach Jahreszeit beträgt diese bspw. in Deutschland 1 Stunde (Winterzeit) oder 2 Stunden (Sommerzeit). Diese Schreibweise findet man bspw. auch im Header von EMails wieder.

Wie man die Zeitdifferenz zwischen GMT-Zeitangabe und Ortszeit ermittelt, das möchten wir Ihnen mit nachfolgendem Tipp zeigen.

' benötigte API-Deklarationen
Private Declare Sub GetSystemTime Lib "kernel32" ( _
  lpSystemTime As SYSTEMTIME)
 
Private Type SYSTEMTIME
  wYear As Integer
  wMonth As Integer
  wDayOfWeek As Integer
  wDay As Integer
  wHour As Integer
  wMinute As Integer
  wSecond As Integer
  wMilliseconds As Integer
End Type
' Gibt die Zeitdifferenz zur GMT-Zeitangabe in Stunden zurück
' (für Deutschland: 1 = Winterzeit, 2 = Sommerzeit)
Public Function GMTDiff() As Long
  Dim nDiff As Long
  Dim st As SYSTEMTIME
 
  ' Systemzeit ermitteln
  GetSystemTime st
 
  ' Zeit-Differenz zur GMT-Zeit in Minuten
  nDiff = DateDiff("n", DateSerial(st.wYear, st.wMonth, st.wDay) + _
    TimeSerial(st.wHour, st.wMinute, st.wSecond), Now)
 
  ' Zeit-Differenz in Stunden
  If (nDiff Mod 60) <> 0 Then nDiff = nDiff - 1
  GMTDiff = nDiff / 60
End Function

Beispiel:

Dim sGMTime As String
sGMTime = Time$ & " " & Format$(GMTDiff(), "+00;-00") & "00"

Tipp:
Durch Abfrage der GMTDiff-Funktion lässt sich sehr schnell feststellen, ob Winterzeit oder Sommerzeit eingestellt ist:

If GMTDiff() = 2 Then
  MsgBox "Sommerzeit ist eingestellt."
Else
  MsgBox "Winterzeit ist eingestellt."
End If



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.