Mit der Funktion mktime lassen sich aus mehreren Einzelkomponenten zusammengestellte Datumsangaben generieren. Mktime liefert als Rückgabewert einen int-Wert (integer), welcher den zu einem individuell eingestellten Datum den zugehörigen Timestamp repräsentiert. Als Parameter erwartet mktime bis zu sieben optionale Parameter, die in vorgegebener Reihenfolge angegeben werden können. Diese Parameter sind allesamt vom Typ int und geben die den Timestamp definierende Werte für die Stunde, Minute, Sekunde, Monat, Tag und das Jahr – in genau dieser Reihenfolge – an.
Der letzte Parameter der Funktion gibt an, ob bei der Zeitangabe die Sommerzeit oder die Winterzeit berücksichtigt werden soll (der Parameter wird mit 1 angegeben) oder nicht (0). Standardmäßig wird -1 für „unknown” angenommen, was dazu führt, dass die Berechnung nach den Vorgaben der Webserver-Konfiguration erfolgt (is_dst = 1). Seit PHP 5.1.0 darf dieser Parameter nicht mehr angegeben werden. Zeitkomponenten, die nicht angegeben wurden, führen zu einer Default-Belegung, die sich aus den aktuellen Datums- und Zeitangaben ergeben. Werden also nur die ersten beiden Angaben (Stunde und Minute) angegeben, so liefert mktime einen Timestamp für die angegebene Stunde und Minute des aktuellen Tages. Die durch date in Strings konvertierten Timestamps des unteren Scripts werden – zur Formatierung mit HTML-Code gespickt – auf der aufgerufenen Internetseite ausgegeben.
<?php // Timestamp für den heutigen Tag zur Uhrzeit 22:55 Uhr // Stunde und Minute wird angegeben; der Rest wird durch einen aktuellen // Timestamp vorgegeben echo date ('l d.m.Y, H:i:s', mktime (22, 55)) . '<br>'; // Angabe der kompletten Zeit echo date ('l d.m.Y, H:i:s', mktime (18, 30, 0)) . '<br>'; // Zusätzlich angegebene Monat und Tag (1. Januar) echo date ('l d.m.Y, H:i:s', mktime (0, 0, 0, 1, 1)) . '<br>'; // Und jetzt mit einer Jahresangabe echo date ('l d.m.Y, H:i:s', mktime (0, 0, 0, 1, 1, 2000)) . '<br>'; // Vorsicht bei einem nicht existierenden Datum // Den 31.02.2008 gab es nicht (in diesem Jahr hatte der Februar 29 Tage) // Generiert wird der Timestamp für den 31. Tag nach dem 1. Februar // Analog geschieht dies auch bei Monaten, die nur 30 Tage haben. Hier // wird stets der 1. des Folgemonats angenommen. echo date ('l d.m.Y, H:i:s', mktime (0, 0, 0, 2, 31, 2008)) . '<br>'; ?>
Sunday 15.09.2024, 22:55:58
Sunday 15.09.2024, 18:30:00
Tuesday 01.01.2008, 00:00:00
Saturday 01.01.2000, 00:00:00
Sunday 02.03.2008, 00:00:00
Aufgrund der Tatsache, dass mktime die angegebenen Parameter auf den realen Kalender umrechnet, ist es auch durch entsprechende Anpassung von Datum- und Zeitinformationen möglich, über die Funktion mktime – und unter Verwendung von Variablen zur Zwischenspeicherung von Werten – einfache Berechnungen durchzuführen. Auf diese Weise lassen sich Fristen errechnen oder andere auf ein Datum bezogene Fragen – etwa welcher Wochentag an einem bestimmten Datum ist – klären. Folgende Beispiele zeigen, wie Sie mit Hilfe von date und der Funktion mktime derartige Berechnungen programmieren können. Die Ausgabe der errechneten Zeit-Informationen erfolgt auch hier wieder mit echo.
<?php // Bestimmtes Datum als Startpunkt für weitere Berechnungen über den Timestamp // festlegen. $ts = mktime (0, 0, 0, 11, 6, 2008); // Teilkomponenten des gesetzten Datums extrahieren $jahr = date ('Y', $ts); $monat = date ('m', $ts); $tag = date ('d', $ts); // Ausgabe des ermittelten Datums, von dem die folgenden Berechnungen aus gehen echo 'Ausgangsdatum: ' . date ('l d.m.Y', $ts) . '<br>'; // Fristen nach einem bestimmten Tag errechen // 14 Tage nach dem aktuellen Datum echo 'In 14 Tagen haben wir folgendes Datum: ' . date ('l d.m.Y', mktime (0, 0, 0, $monat, $tag + 14, $jahr)) . '<br>'; // 4 Wochen nach dem Termin echo '4-Wöchige Frist: ' . date ('l d.m.Y', mktime (0, 0, 0, $monat, $tag + 28, $jahr)) . '<br>'; // Gleicher Tag im nächsten Jahr ist welcher Wochentag? echo 'Nächstes Jahr ist dieser Tag ein: ' . date ('l', mktime (0, 0, 0, $monat, $tag, $jahr + 1)) . '<br>'; ?>
Ausgangsdatum: Thursday 06.11.2008
In 14 Tagen haben wir folgendes Datum: Thursday 20.11.2008
4-Wöchige Frist: Thursday 04.12.2008
Nächstes Jahr ist dieser Tag ein: Friday
<?php // Uhrzeit, die als Grundlage für die folgenden Berechnungen dienen, festlegen $ts = mktime (13, 30, 0); // Teilkomponenten der festgelegten Zeit auslesen und in Variablen speichern $stunde = date ('H', $ts); $minute = date ('i', $ts); $sekunde = date ('s', $ts); // Ausgabe des ermittelten Datums, von dem die folgenden Berechnungen aus gehen echo 'Ausgangszeit: ' . date ('H:i:s', $ts) . '<br>'; // Einige Kombinationen zur Berechnung der Zeit (time) echo 'Zeit nach 30 Minuten: ' . date ('H:i:s', mktime ($stunde, $minute + 30, $sekunde)) . '<br>'; echo '12 Stunden später: ' . date ('H:i:s', mktime ($stunde + 12, $minute, $sekunde)) . '<br>'; echo 'Nach 4000 Sekunden: ' . date ('H:i:s', mktime ($stunde, $minute, $sekunde + 4000)) . '<br>'; ?>
Ausgangszeit: 13:30:00
Zeit nach 30 Minuten: 14:00:00
12 Stunden später: 01:30:00
Nach 4000 Sekunden: 14:36:40
¬ Menu
¬ Gratis Download
¬ Tutorials
¬ Seminare
¬ Yoga
¬ Insolvenzrecht
¬ News
15.08.2008Schleifen in PHP: Die While-Schleife » mehr 13.08.2008Nutzung von Variablen unter PHP: Definition, Sichtbarkeit und vordefinierte Variablen » mehr 11.08.2008Ausgabe von Datum und Zeit mit PHP nach Konvertierung in ein String » mehr Eine vollständige News-Liste ist auf der News-Seite zugänglich.
¬ Foren
¬ Buchtipp
Einstieg in PHP 5.1 & MySQL 5, m. CD-ROM
Weitere PHP Bücher finden Sie unter PHP Literatur
PHP Programmierer •
Homepage Check •
Suchmaschinenmarketing (SEM)