Rubrik: Datum/Zeit und Timer · Datums- und Zeit-Funktionen | VB-Versionen: VB2005, VB2008 | 28.05.09 |
Zeit-Differenz berechnen Für viele User ein Problem: das Berechnen der Differenz zweier Zeitangaben. Aber nicht mehr lange ;-) | ||
Autor: Dieter Otter | Bewertung: | Views: 27.110 |
www.tools4vb.de | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Viele User haben mit dem Berechnen der Zeitdifferenz zweier Uhrzeitangaben enorme Probleme. Dabei stellt uns das .NET Framework doch sehr gute und vielseitige Datums- und Zeitfunktionen zur Verüfung.
Für das Berechnen der Zeitdifferenz zweier Uhrzeiten nimmt am besten ein TimeSpan-Objekt.
' zwei Uhrzeiten festlegen Dim sTime1 As String = "11:43" Dim sTime2 As String = "16:44" ' Uhrzeiten in TimeSpan-Objekte überführen Dim time1 As TimeSpan = TimeSpan.Parse(sTime1) Dim time2 As TimeSpan = TimeSpan.Parse(sTime2) ' Zeitdifferenz in Minuten berechnen Dim nMin As Integer = 0 With time2.Subtract(time1) nMin = .Hours * 60 + .Minutes End With ' Ausgabe der Zeit-Differenz MsgBox("Die Differenz beträgt " & CStr(nMin) & " Minuten")
Als Ergebnis bekommen wir den Wert 301, was 5 Stunden und 1 Minute entspricht. Also alles korrekt.
Jetzt kann es aber durchaus vorkommen, dass als zweite Zeitangabe eine Uhrzeit nach 0:00 Uhr vorliegt - z.B. 01:44. Würde man die Zeitdifferenz mit obigen Code berechnen, würde man als Ergebnis -599 bekommen. Also nicht korrekt.
In diesem Fall braucht man aber einfach nur einen Tag (umgerechnet in Minuten) hinzuaddieren und schon stimmt das Ergebnis wieder.
''' <summary> ''' Ermittelt die Zeit-Differenz zweier Uhrzeiten ''' </summary> ''' <param name="sTime1">1. Zeitangabe</param> ''' <param name="sTime2">2. Zeitangabe</param> ''' <returns>Differenz in Minuten</returns> Public Function TimeDiff(ByVal sTime1 As String, ByVal sTime2 As String) As Integer ' Uhrzeiten in TimeSpan-Objekte überführen Dim time1 As TimeSpan = TimeSpan.Parse(sTime1) Dim time2 As TimeSpan = TimeSpan.Parse(sTime2) ' Zeitdifferenz in Minuten berechnen Dim nMin As Integer = 0 With time2.Subtract(time1) nMin = .Hours * 60 + .Minutes ' Falls negativ, 24 Stunden hinzuaddieren If nMin < 0 Then nMin += 24 * 60 End With Return (nMin) End Function
Um den Rückgabewert, also die Zeit-Differenz in Minuten, im Format Stunde:Minute anzuzeigen, folgende Codezeile verwenden:
' Zeit-Differenz in Minuten Dim nMin As Integer = TimeDiff("11:43", "16:44") ' Zeit-Differenz formatiert ausgeben Dim sTime As String = New TimeSpan(0, nMin, 0).ToString.Substring(0, 5) MsgBox(sTime)