Heute zeigen wir Ihnen eine Möglichkeit zur Ermittlung der Dauer zwischen 2 Zeitpunkten, bei der das Datum und die Uhrzeit berücksichtigt werden. Somit funktioniert die Zeitnahme auch, wenn die Endzeit kleiner ist, als die Startzeit z.B. beim Überschreiten von 00:00 Uhr (Mitternacht). Es wird eine Startzeit gesetzt (z.B. bei Programm-Start). Danach kann die Zeitnahme jederzeit durchgeführt werden, um die bis dahin verstrichene Zeit anzuzeigen. Es wird bei jeder Zeitnahme die aktuelle Zeit mit der Startzeit verglichen und die Differenz als Dauer in das Format "hh:mm:ss" umgewandelt. Dadurch kann die Zeitnahme unabhängig von einem Timer ausgeführt werden, um z.B. die Startzeit und die Endzeit eines Backup-Programms in ein Logbuch einzutragen. Wird die Zeitnahme über einen Timer gesteuert, kann die jeweilige (Programm-)Dauer ständig (z.B. in einem Label) angezeigt werden. Diese Version ist fähig, eine Zeitnahme über 24 Stunden zu ermitteln. Fügen Sie nachfolgenden Code in ein Modul ein: Option Explicit Private vntStartZeit As Variant Private vntEndZeit As Variant ' Ermitteln des Datums und der Zeit beim Start der Zeitnahme Public Sub SetzeStartzeit() vntStartZeit = Now End Sub ' Zeit-Differenz berechnen Public Function Zeitnahme() As Variant Dim lngZeitDiff As Long If IsEmpty(vntStartZeit) Then ' Falls keine Startzeit gesetzt wurde, abbrechen MsgBox "Zuerst Startzeit eingeben.", vbInformation Else ' Ermitteln des Datums und der Zeit bei der Zeitnahme vntEndZeit = Now ' Anzahl vergangener Sekunden seit Setzen der Startzeit lngZeitDiff = DateDiff("s", vntStartZeit, vntEndZeit) ' Ausgabe der Zeitnahme (Sekunden in hh:mm:ss umwandeln) Zeitnahme = DateAdd("s", lngZeitDiff, 0) End If End Function ' Startzeit löschen ' (Nur der Vollständigkeit halber. Wird normalerweise nicht benötigt, ' da ein erneutes Setzen der Startzeiz die alte überschreibt.) Public Sub ResetStartzeit() vntStartZeit = Empty ' nicht vergessen einen evtl. Timer zu stoppen End Sub Beispiel für den Aufruf: Private Sub Command1_Click() ' Startzeit setzen SetzeStartzeit ' Aktion ausführen ... ' Zeitnahme MsgBox "Die Aktion dauerte: " & Zeitnahme() End Sub Dieser Tipp wurde bereits 20.435 mal aufgerufen.
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv (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. |
sevGraph (VB/VBA) ![]() Grafische Auswertungen Präsentieren Sie Ihre Daten mit wenig Aufwand in grafischer Form. sevGraph unterstützt hierbei Balken-, Linien- und Stapel-Diagramme (Stacked Bars), sowie 2D- und 3D-Tortendiagramme und arbeitet vollständig datenbankunabhängig! Tipp des Monats Heinz Prelle Datei-Mehrfachauswahl an eine ListBox übergeben Dieser Tipp zeigt, wie Sie über den Windows-CommonDialog eine Mehrfach-Dateiauswal realisieren... Access-Tools Vol.1 ![]() Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
|
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. |
|||||||||||||||||


Zeitnahme ohne Timer


