strftime

(PHP 4, PHP 5, PHP 7, PHP 8)

strftimeFormatiere eine Zeit-/Datumsangabe gemäß dem Gebietsschema

Beschreibung

strftime ( string $format , int $timestamp = time() ) : string

Formatiere eine Zeit-/Datumsangabe gemäß dem Gebietsschema. Monats- und Wochentagsnamen sowie andere sprachabhängige Zeichenketten werden entsprechend des per setlocale() eingestellten Wertes dargestellt.

Es ist durchaus möglich, dass Ihre C-Bibliothek nicht alle angegebenen Formatierungszeichen erkennt. In diesem Fall werden diese Zeichen von der PHP-Funktion strftime() nicht unterstützt. Zusätzlich unterstützen nicht alle Plattformen negative Werte eines Timestamps, deshalb könnte der Wertebereich eines Datums durch den Beginn der Unix Epoche begrenzt sein. Das bedeutet, dass z.B. %e, %T, %R und %D (und vielleicht noch weitere) und Zeitangaben vor dem Jan 1, 1970 auf Windowssystemen, einigen Linuxdistributionen und einigen anderen Betriebssytemen nicht funktionieren. Für Windowsbetriebssysteme finden Sie eine komplette Übersicht der gültigen Platzhalter im Formatierungsstring im » MSDN.

Parameter-Liste

format

Folgende Zeichen werden in der format Parameterzeichenkette erkannt
format Beschreibung Wertebeispiel
Tag --- ---
%a Abgekürzter Name des Wochentages So bis Sa
%A Ausgeschriebener Name des Wochentages Sonntag bis Samstag
%d Tag des Monats als zweistellige Zahl (ggf. mit vorangestellten Nullen) 01 bis 31
%e Tag des Monats als Dezimal-Wert; einstelligen Werten wird ein Leerzeichen voran gestellt. Unter Windows nicht wie beschrieben implementiert; siehe weiter unten für weitere Informationen. 1 bis 31
%j Tag des Jahres als dreistellige Zahl, ggf. mit vorangestellten Nullen 001 bis 366
%u ISO-8601 numerische Darstellung des Wochentages 1 (für Montag) bis 7 (für Sonntag)
%w Numerische Darstellung des Wochentags 0 (für Sonntag) bis 6 (für Samstag)
Woche --- ---
%U Nummer der Kalenderwoche des gegebenen Jahres, beginnend mit dem ersten Sonntag als erste Woche 13 (für die 13. Kalenderwoche des Jahres)
%V ISO-8601:1988 Kalenderwochennummer des gegebenen Jahres, beginnend mit der ersten Woche des Jahres mit wenigstens 4 Wochentagen, wobei Montag der Start der Kalenderwoche ist 01 bis 53 (wobei 53 eine überlappende Woche repräsentiert)
%W Numerische Darstellung der Kalenderwoche, beginnend mit dem ersten Montag als erste Woche 46 (für die 46. Woche des Jahres, die mit einem Montag beginnt)
Monat --- ---
%b Abgekürzter Monatsname gemäß dem Gebietsschema Jan bis Dez
%B Vollständiger Monatsname gemäß dem Gebietsschema Januar bis Dezember
%h Abgekürzter Monatsname gemäß dem Gebietsschema (ein Alias von %b) Jan bis Dez
%m Zweistellige numerische Darstellung des Monats 01 (für Januar) bis 12 (für Dezember)
Jahr --- ---
%C Zweistellige numerische Darstellung des Jahrhunders (Jahr geteilt durch 100, abgerundet zu einer Ganzzahl) 19 für das 20. Jahrhundert
%g Zweistellige numerische Darstellung des Jahres gemäß dem ISO-8601:1988 Standard (siehe %V) Beispiel: 09 für die Woche des 6. Januar 2009
%G Die vollständige vierstellige numerische Version von %g Beispiel: 2008 für die Woche des 3. Januar 2009
%y Zweistellige numerische Darstellung des Jahres Beispiel: 09 für 2009, 79 für 1979
%Y Vierstellige numerische Darstellung des Jahres Beispiel: 2038
Zeit --- ---
%H Zweistellige numerische Darstellung der Stunde im 24-Stunden-Format 00 bis 23
%k Stunde im 24-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden 0 bis 23
%I Zweistellige numerische Darstellung der Stunde im 12-Stunden-Format 01 bis 12
%l (kleines 'L') Stunde im 12-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden 1 bis 12
%M Zweistellige numerische Darstellung der Minute 00 bis 59
%p 'AM' oder 'PM' in Großbuchstaben, basierend auf der gegebenen Zeit Beispiel: AM für 00:31, PM für 22:23
%P 'am' oder 'pm' in Kleinbuchstaben, basierend auf der gegebenen Zeit Beispiel: am für 00:31, pm für 22:23
%r Das gleiche wie "%I:%M:%S %p" Beispiel: 09:34:17 PM für 21:34:17
%R Das gleiche wie "%H:%M" Beispiel: 00:35 für 12:35 AM, 16:44 für 4:44 PM
%S Zweistellige numerische Darstellung der Sekunde 00 bis 59
%T Das gleiche wie "%H:%M:%S" Beispiel: 21:34:17 für 09:34:17 PM
%X Bevorzugte Zeitdarstellung gemäß dem Gebietsschema, ohne Datumsangabe Beispiel: 03:59:16 oder 15:59:16
%z Der Zeitzonen-Versatz. Unter Windows nicht wie beschrieben implementiert; siehe weiter unten für weitere Informationen. Beispiel: -0500 für US Eastern Time
%Z Das Zeitzonenkürzel. Unter Windows nicht wie beschrieben implementiert; siehe weiter unten für weitere Informationen. Beispiel: EST für Eastern Time
Datums- und Zeitstempel --- ---
%c Bevorzugter Datums- und Zeitstempel gemäß dem Gebietsschema Beispiel: 05.02.2009 00:45:10 für den 5. Februar 2009 um 00:45:10
%D Das gleiche wie "%m/%d/%y" Example: 02/05/09 für den 5. Februar 2009
%F Same as "%Y-%m-%d" (oft verwendet für Datenbankzeitstempel) Example: 2009-02-05 für den 5. Februar 2009
%s Zeitstempel der Unix-Epochenzeit (das gleiche wie die time() Funktion) Beispiel: 305815200 für den 10. September 1979, 08:40:00
%x Bevorzugte Datumsdarstellung gemäß dem Gebietsschema, ohne Zeitangabe Beispiel: 02/05/09 für den 5. Februar 2009
Verschiedenes --- ---
%n Ein Zeilenvorschubzeichen ("\n") ---
%t Ein Tabulatorzeichen ("\t") ---
%% Ein buchstäbliches Prozentzeichen ("%") ---

Die Höchstlänge dieses Parameters sind 1023 Zeichen.

Warnung

Im Gegensatz zu ISO-9899:1999 beginnt Sun Solaris mit Sonntag als 1. Daraus folgt, dass %u nicht wie in diesem Handbuch beschrieben funktionieren kann.

Warnung

Nur für Windows:

Der %e Platzhalter wird nicht in der Windows Implementierung dieser Funktion unterstützt. Um diesen Wert zu erhalten, kann der %#d Platzhalter statt dessen verwendet werden. Das Beispiel weiter unten zeigt wie eine Plattform übergreifende kompatible Funktion geschrieben werden kann.

Die %z und %Z Platzhalter geben beide den Namen der Zeitzone anstelle des Versatzes oder des Kürzels zurück.

Warnung

Nur für macOS: Der %P Platzhalter wird nicht in der macOS Implementierung dieser Funktion unterstüzt.

timestamp

Der optionale Parameter timestamp ist ein Unix-Timestamp als int oder die aktuelle lokale Zeit, wenn timestamp nicht übergeben wurde oder null ist. Er entspricht dann also dem Ergebnis der Funktion time().

Rückgabewerte

Gibt eine Zeichenkette zurück, die gemäß format unter Verwendung des angegebenen timestamp oder der aktuellen Ortszeit, falls kein Zeitstempel angegeben wurde, formatiert ist. Monats- und Wochentagsnamen sowie andere sprachabhängige Zeichenketten werden entsprechend des per setlocale() eingestellten Wertes dargestellt.

Fehler/Exceptions

Jeder Aufruf der Datums- und Zeitfunktionen generiert eine E_NOTICE-Warnung, wenn die Zeitzone ungültig ist und eine E_STRICT-Nachricht oder eine E_WARNING-Warnung, wenn die Systemeinstellung oder die TZ-Umgebungsvariable genutzt wird. Siehe auch date_default_timezone_set()

Da die Ausgabe von der unterliegenden C-Bibliothek abhängt, werden einige Konversionsangaben nicht unterstützt. Unter Window führt die Angabe von Konversionsangaben zu 5 E_WARNING Meldungen, und die Funktion gibt false zurück. Unter anderen Betriebssystemen werden unter Umständen keine E_WARNING Meldungen erzeugt, und die Ausgabe kann die Konversionsangaben unverändert enthalten.

Beispiele

Dieses Beispiel funktioniert nur, wenn auf Ihrem System die entsprechenden Locales installiert sind.

Beispiel #1 strftime() locale Beispiel

<?php
setlocale
(LC_TIME"C");
echo 
strftime("%A");
setlocale(LC_TIME"fi_FI");
echo 
strftime(" in Finnish is %A,");
setlocale(LC_TIME"fr_FR");
echo 
strftime(" in French %A and");
setlocale(LC_TIME"de_DE");
echo 
strftime(" in German %A.\n");
?>

Beispiel #2 ISO 8601:1988 Wochennummer Beispiel

<?php
/*     Dezember 2002 / Januar 2003
ISOWk  Mo  Di  Mi  Do  Fr  Sa  So
----- ----------------------------
51     16  17  18  19  20  21  22
52     23  24  25  26  27  28  29
1      30  31   1   2   3   4   5
2       6   7   8   9  10  11  12
3      13  14  15  16  17  18  19   */

// Ausgabe: 28.12.2002 - %V,%G,%Y = 52,2002,2002
echo "28.12.2002 - %V,%G,%Y = " strftime("%V,%G,%Y"strtotime("12/28/2002")) . "\n";

// Ausgabe: 30.12.2002 - %V,%G,%Y = 1,2003,2002
echo "30.12.2002 - %V,%G,%Y = " strftime("%V,%G,%Y"strtotime("12/30/2002")) . "\n";

// Ausgabe: 03.01.2003 - %V,%G,%Y = 1,2003,2003
echo "03.01.2003 - %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("1/3/2003")) . "\n";

// Ausgabe: 10.01.2003 - %V,%G,%Y = 2,2003,2003
echo "10.01.2003 - %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("1/10/2003")) . "\n";



/*     Dezember 2004 / Januar 2005
ISOWk  Mo  Di  Mi  Do  Fr  Sa  So
----- ----------------------------
51     13  14  15  16  17  18  19
52     20  21  22  23  24  25  26
53     27  28  29  30  31   1   2
1       3   4   5   6   7   8   9
2      10  11  12  13  14  15  16   */

// Ausgabe: 23.12.2004 - %V,%G,%Y = 52,2004,2004
echo "23.12.2004 - %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("12/23/2004")) . "\n";

// Ausgabe: 31.12.2004 - %V,%G,%Y = 53,2004,2004
echo "31.12.2004- %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("12/31/2004")) . "\n";

// Ausgabe: 02.01.2005 - %V,%G,%Y = 53,2004,2005
echo "02.01.2005 - %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("1/2/2005")) . "\n";

// Ausgabe: 03.01.2005 - %V,%G,%Y = 1,2005,2005
echo "03.01.2005 - %V,%G,%Y = " strftime("%V,%G,%Y",strtotime("1/3/2005")) . "\n";

?>

Beispiel #3 Plattform übergreifendes Beispiel unter Verwendung des %e Platzhalters

<?php

// 1. Januar ergibt: '%e%1%' (%%, e, %%, %e, %%)
$format '%%e%%%e%%';

// Prüfe auf Windows, um den %e Platzhalter korrekt zu ersetzen
if (strtoupper(substr(PHP_OS03)) == 'WIN') {
    
$format preg_replace('#(?<!%)((?:%%)*)%e#''\1%#d'$format);
}

echo 
strftime($format);
?>

Beispiel #4 Zeige alle bekannten und unbekannten Formate an.

<?php
// Beschreibe die Formate.
$strftimeFormats = array(
    
'A' => 'Ausgeschriebener Name des Wochentages',
    
'B' => 'Vollständiger Monatsname gemäß dem Gebietsschema',
    
'C' => 'Zweistellige numerische Darstellung des Jahrhunders (Jahr geteilt durch 100, abgerundet zu einer Ganzzahl)',
    
'D' => 'Das gleiche wie "%m/%d/%y"',
    
'E' => '',
    
'F' => 'Same as "%Y-%m-%d"',
    
'G' => 'Die vollständige vierstellige numerische Version von %g',
    
'H' => 'Zweistellige numerische Darstellung der Stunde im 24-Stunden-Format',
    
'I' => 'Zweistellige numerische Darstellung der Stunde im 12-Stunden-Format',
    
'J' => '',
    
'K' => '',
    
'L' => '',
    
'M' => 'Zweistellige numerische Darstellung der Minute',
    
'N' => '',
    
'O' => '',
    
'P' => '"am" oder "pm" in Kleinbuchstaben, basierend auf der gegebenen Zeit',
    
'Q' => '',
    
'R' => 'Das gleiche wie "%H:%M"',
    
'S' => 'Zweistellige numerische Darstellung der Sekunde',
    
'T' => 'Das gleiche wie "%H:%M:%S"',
    
'U' => 'Nummer der Kalenderwoche des gegebenen Jahres, beginnend mit dem ersten Sonntag als erste Woche',
    
'V' => 'ISO-8601:1988 Kalenderwochennummer des gegebenen Jahres, beginnend mit der ersten Woche des Jahres mit wenigstens 4 Wochentagen, wobei Montag der Start der Kalenderwoche ist',
    
'W' => 'Numerische Darstellung der Kalenderwoche, beginnend mit dem ersten Montag als erste Woche',
    
'X' => 'Bevorzugte Zeitdarstellung gemäß dem Gebietsschema, ohne Datumsangabe',
    
'Y' => 'Vierstellige numerische Darstellung des Jahres',
    
'Z' => 'Das Zeitzonenkürzel oder die Zeitzone (abhängig vom Betriebssystem)',
    
'a' => 'Abgekürzter Name des Wochentages',
    
'b' => 'Abgekürzter Monatsname gemäß dem Gebietsschema',
    
'c' => 'Bevorzugter Datums- und Zeitstempel gemäß dem Gebietsschema',
    
'd' => 'Tag des Monats als zweistellige Zahl (ggf. mit vorangestellten Nullen)',
    
'e' => 'Tag des Monats als Dezimal-Wert; einstelligen Werten wird ein Leerzeichen voran gestellt',
    
'f' => '',
    
'g' => 'Zweistellige numerische Darstellung  des Jahres gemäß dem ISO-8601:1988 Standard (siehe %V)',
    
'h' => 'Abgekürzter Monatsname gemäß dem Gebietsschema (ein Alias von %b)',
    
'i' => '',
    
'j' => 'Tag des Jahres als dreistellige Zahl, ggf. mit vorangestellten Nullen',
    
'k' => 'Stunde im 24-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden',
    
'l' => 'Stunde im 12-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden',
    
'm' => 'Zweistellige numerische Darstellung des Monats',
    
'n' => 'Ein Zeilenvorschubzeichen ("\n")',
    
'o' => '',
    
'p' => '"AM" oder "PM" in Großbuchstaben, basierend auf der gegebenen Zeit',
    
'q' => '',
    
'r' => 'Das gleiche wie "%I:%M:%S %p"',
    
's' => 'Zeitstempel der Unix-Epochenzeit',
    
't' => 'Ein Tabulatorzeichen ("\t")',
    
'u' => 'ISO-8601 numerische Darstellung des Wochentages',
    
'v' => '',
    
'w' => 'Numerische Darstellung des Wochentags',
    
'x' => 'Bevorzugte Datumsdarstellung gemäß dem Gebietsschema, ohne Zeitangabe',
    
'y' => 'Zweistellige numerische Darstellung des Jahres',
    
'z' => 'Entweder der Zeitzonenversatz zu UTC oder das Zeitzonenkürzel (depends on operating system)',
    
'%' => 'Ein buchstäbliches Prozentzeichen ("%")',
);

// Ergebnisse.
$strftimeValues = array();

// Werte die Formate aus während jegliche Fehler unterdrückt werden.
foreach($strftimeFormats as $format => $description){
    if (
False !== ($value = @strftime("%{$format}"))){
        
$strftimeValues[$format] = $value;
    }
}

// Ermittle den längsten Wert.
$maxValueLength max(array_map('strlen'$strftimeValues));

// Berichte bekannte Formate.
foreach($strftimeValues as $format => $value){
    echo 
"Bekanntes Format   : '{$format}' = "str_pad("'{$value}'"$maxValueLength), " ( {$strftimeFormats[$format]} )\n";
}

// Berichte unbekannte Formate.
foreach(array_diff_key($strftimeFormats$strftimeValues) as $format => $description){
    echo 
"Unbekanntes Format : '{$format}'   "str_pad(' '$maxValueLength), ($description " ( {$description} )" ''), "\n";
}
?>

Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:

Bekanntes Format   : 'A' = 'Freitag'                ( Ausgeschriebener Name des Wochentages )
Bekanntes Format   : 'B' = 'Dezember'               ( Vollständiger Monatsname gemäß dem Gebietsschema )
Bekanntes Format   : 'C' = '20'                     ( Zweistellige numerische Darstellung des Jahrhunders (Jahr geteilt durch 100, abgerundet zu einer Ganzzahl) )
Bekanntes Format   : 'D' = '12/03/10'               ( Das gleiche wie "%m/%d/%y" )
Bekanntes Format   : 'F' = '2010-12-03'             ( Same as "%Y-%m-%d" )
Bekanntes Format   : 'G' = '2010'                   ( Die vollständige vierstellige numerische Version von %g )
Bekanntes Format   : 'H' = '11'                     ( Zweistellige numerische Darstellung der Stunde im 24-Stunden-Format )
Bekanntes Format   : 'I' = '11'                     ( Zweistellige numerische Darstellung der Stunde im 12-Stunden-Format )
Bekanntes Format   : 'M' = '24'                     ( Zweistellige numerische Darstellung der Minute )
Bekanntes Format   : 'R' = '11:24'                  ( Das gleiche wie "%H:%M" )
Bekanntes Format   : 'S' = '44'                     ( Zweistellige numerische Darstellung der Sekunde )
Bekanntes Format   : 'T' = '11:24:44'               ( Das gleiche wie "%H:%M:%S" )
Bekanntes Format   : 'U' = '48'                     ( Nummer der Kalenderwoche des gegebenen Jahres, beginnend mit dem ersten Sonntag als erste Woche )
Bekanntes Format   : 'V' = '48'                     ( ISO-8601:1988 Kalenderwochennummer des gegebenen Jahres, beginnend mit der ersten Woche des Jahres mit wenigstens 4 Wochentagen, wobei Montag der Start der Kalenderwoche ist )
Bekanntes Format   : 'W' = '48'                     ( Numerische Darstellung der Kalenderwoche, beginnend mit dem ersten Montag als erste Woche )
Bekanntes Format   : 'X' = '11:24:44'               ( Bevorzugte Zeitdarstellung gemäß dem Gebietsschema, ohne Datumsangabe )
Bekanntes Format   : 'Y' = '2010'                   ( Vierstellige numerische Darstellung des Jahres )
Bekanntes Format   : 'Z' = 'Mitteleuropäische Zeit' ( Das Zeitzonenkürzel oder die Zeitzone (abhängig vom Betriebssystem) )
Bekanntes Format   : 'a' = 'Fr'                     ( Abgekürzter Name des Wochentages )
Bekanntes Format   : 'b' = 'Dez'                    ( Abgekürzter Monatsname gemäß dem Gebietsschema )
Bekanntes Format   : 'c' = '03.12.2010 11:24:44'    ( Bevorzugter Datums- und Zeitstempel gemäß dem Gebietsschema )
Bekanntes Format   : 'd' = '03'                     ( Tag des Monats als zweistellige Zahl (ggf. mit vorangestellten Nullen) )
Bekanntes Format   : 'e' = ' 3'                     ( Tag des Monats als Dezimal-Wert; einstelligen Werten wird ein Leerzeichen voran gestellt )
Bekanntes Format   : 'g' = '10'                     ( Zweistellige numerische Darstellung  des Jahres gemäß dem ISO-8601:1988 Standard (siehe %V) )
Bekanntes Format   : 'h' = 'Dez'                    ( Abgekürzter Monatsname gemäß dem Gebietsschema (ein Alias von %b) )
Bekanntes Format   : 'j' = '337'                    ( Tag des Jahres als dreistellige Zahl, ggf. mit vorangestellten Nullen )
Bekanntes Format   : 'm' = '12'                     ( Zweistellige numerische Darstellung des Monats )
Bekanntes Format   : 'n' = '
'                      ( Ein Zeilenvorschubzeichen ("\n") )
Bekanntes Format   : 'r' = '11:24:44'               ( Das gleiche wie "%I:%M:%S %p" )
Bekanntes Format   : 't' = '	'                   ( Ein Tabulatorzeichen ("\t") )
Bekanntes Format   : 'u' = '5'                      ( ISO-8601 numerische Darstellung des Wochentages )
Bekanntes Format   : 'w' = '5'                      ( Numerische Darstellung des Wochentags )
Bekanntes Format   : 'x' = '03.12.2010'             ( Bevorzugte Datumsdarstellung gemäß dem Gebietsschema, ohne Zeitangabe )
Bekanntes Format   : 'y' = '10'                     ( Zweistellige numerische Darstellung des Jahres )
Bekanntes Format   : 'z' = '+0100'                  ( Entweder der Zeitzonenversatz zu UTC oder das Zeitzonenkürzel (depends on operating system) )
Bekanntes Format   : '%' = '%'                      ( Ein buchstäbliches Prozentzeichen ("%") )
Unbekanntes Format : 'E'                           
Unbekanntes Format : 'J'                           
Unbekanntes Format : 'K'                           
Unbekanntes Format : 'L'                           
Unbekanntes Format : 'N'                           
Unbekanntes Format : 'O'                           
Unbekanntes Format : 'P'                            ( "am" oder "pm" in Kleinbuchstaben, basierend auf der gegebenen Zeit )
Unbekanntes Format : 'Q'                           
Unbekanntes Format : 'f'                           
Unbekanntes Format : 'i'                           
Unbekanntes Format : 'k'                            ( Stunde im 24-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden )
Unbekanntes Format : 'l'                            ( Stunde im 12-Stunden-Format mit einem Leerzeichen vor einstelligen Stunden )
Unbekanntes Format : 'o'                           
Unbekanntes Format : 'p'                            ( "AM" oder "PM" in Großbuchstaben, basierend auf der gegebenen Zeit )
Unbekanntes Format : 'q'                           
Unbekanntes Format : 's'                            ( Zeitstempel der Unix-Epochenzeit )
Unbekanntes Format : 'v'                           

Anmerkungen

Hinweis: %G und %V, die auf ISO 8601:1988 Wochennummern basieren, können unerwartete (obgleich richtige) Ergebnisse ergeben, wenn das Nummernsystem nicht gründlich verstanden wird. Siehe die %V Beispiele auf dieser Handbuchseite.

Siehe auch

add a note add a note

User Contributed Notes 40 notes

up
48
Bondas Timotei
12 years ago
If strange characters are returned use utf8_encode(strftime()) for UTF-8 characters
up
11
aaronw at catalyst dot net dot nz
6 years ago
The page mentions that the available conversion specifiers may be different in "Windows, some Linux distributions, and a few other operating systems".

Specifically, the list of specifiers on this page is basically those from standard GNU/Linux (but without %E, %O, and %+), which is a combination of specifiers from a few different standards. See: http://man7.org/linux/man-pages/man3/strftime.3.html

This means that, if you're not using Linux, or your Linux distro has a different C library than glibc, there *will* probably be at least a few differences in the supported specifiers. Windows has the most differences, but I've also encountered differences in Alpine Linux (which uses musl intsead of glibc) and BSD.
up
9
raf at sns dot pm
8 years ago
For all those who work with WampServer on Windows,
I propose you a formatting(layout) of date as " Friday, January 1st, 2016 " instead of " Friday, January 01st, 2016 " (note the zero in front of 1) which works at the same time on Windows / WampServer and on (on-line) Linux / waiter.
There are problems with "%e" - > which(who) works on Linux and not on Windows - > "%#d" (this works on windows/wampserver)
I simply made a condition:
<?php
if ($_SERVER['SERVER_NAME'] == "website.com") // On line
{
  
$number_of_the_day= "%e"; // Number of the day without "0"
}
else
{
  
$number_of_the_day = "%#d"// The same on Windows/Wampserver
}

setlocale(LC_TIME, 'fr_FR.utf8','fra'); // I'm french !

// i use this fonction ucfirst('string') for "V" Maj. and "J" Maj.

echo ucfirst(strftime('%A '.$number_of_the_day.' %B %Y'));

//  "Vendredi 1 Janvier 2016"  (->  without "0")
?>
Here we are, I hope to have helped.
up
9
ciprianmp at yahoo dot com
13 years ago
This worked for me to distinguish between windows and linux, for stripping leading zeros from days/months in the short formats (like for Czech):
stristr(PHP_OS,"win") ? "%#d.%#m.%Y" : "%-d.%-m.%Y"
up
7
th1nk3r at gmail dot DELETETHIS dot com
17 years ago
Function strftime() use the locales installed in your system (linux).

If you are like me and only leave in the system the locales you use normally (en_US and your own language locale, like es_ES), you'll only be able to use the locales installed. If your application is translated to other languages, you need these locales too.

The name of the locale in your system is important too. This can be a problem when you want to distribute the app.

If you have this locales in your system:
en_US/ISO-8859-1
en_US.UTF-8/UTF-8
es_ES/ISO-8859-1
es_ES@euro/ISO-8859-15
es_ES.UTF-8/UTF-8
es_ES@euro/UTF-8

and use setlocale('es_ES'), the result will use the iso-8859-1 charset even if you have all your system, files and configuration options in UTF-8. To receive content in UTF-8, in this example, you need to use setlocale('es_ES.UTF-8') or setlocale('es_ES.UTF-8@UTF-8').

The definition of locales can change from one system to another, and so the charset from the results.
up
5
baptiste dot place at utopiaweb dot fr
14 years ago
Created this small method to convert a date format to a strftime format. One format is enough to learn :)

<?php
/**
* Convert a date format to a strftime format
*
* Timezone conversion is done for unix. Windows users must exchange %z and %Z.
*
* Unsupported date formats : S, n, t, L, B, G, u, e, I, P, Z, c, r
* Unsupported strftime formats : %U, %W, %C, %g, %r, %R, %T, %X, %c, %D, %F, %x
*
* @param string $dateFormat a date format
* @return string
*/
public static function dateFormatToStrftime($dateFormat) {
   
   
$caracs = array(
       
// Day - no strf eq : S
       
'd' => '%d', 'D' => '%a', 'j' => '%e', 'l' => '%A', 'N' => '%u', 'w' => '%w', 'z' => '%j',
       
// Week - no date eq : %U, %W
       
'W' => '%V'
       
// Month - no strf eq : n, t
       
'F' => '%B', 'm' => '%m', 'M' => '%b',
       
// Year - no strf eq : L; no date eq : %C, %g
       
'o' => '%G', 'Y' => '%Y', 'y' => '%y',
       
// Time - no strf eq : B, G, u; no date eq : %r, %R, %T, %X
       
'a' => '%P', 'A' => '%p', 'g' => '%l', 'h' => '%I', 'H' => '%H', 'i' => '%M', 's' => '%S',
       
// Timezone - no strf eq : e, I, P, Z
       
'O' => '%z', 'T' => '%Z',
       
// Full Date / Time - no strf eq : c, r; no date eq : %c, %D, %F, %x 
       
'U' => '%s'
   
);
   
    return
strtr((string)$dateFormat, $caracs);
}
?>

I use it with this condition on a date format :
if(preg_match("/(D|l|F|M)/", $format))
up
2
Anonymous
13 years ago
%V may fail with some systems (Windows XP, at least). Here is a function that should work to get the week number of a day (timestamped), according to ISO 8601.

"should work" as in "it is working with my understanding of this norm", where 1st of january can be week 52, 53 or 01. Hopefully.

testing (php_uname("s") == "Windows NT") or equivalent can be an option (when switching between Wampserver and a GNU server, for instance).

Please, erase and correct my message if there is any error.

<?php
function week_isonumber ($time) {
// When strftime("%V") fails, some unoptimized workaround
//
// http://en.wikipedia.org/wiki/ISO_8601 : week 1 is "the week with the year's first Thursday in it (the formal ISO definition)"

   
$year = strftime("%Y", $time);

   
$first_day = strftime("%w", mktime(0, 0, 0, 1, 1, $year));
   
$last_day = strftime("%w", mktime(0, 0, 0, 12, 31, $year));
       
   
$number = $isonumber = strftime("%W", $time);

   
// According to strftime("%W"), 1st of january is in week 1 if and only if it is a monday
   
if ($first_day == 1)
       
$isonumber--;

   
// 1st of january is between monday and thursday; starting (now) at 0 when it should be 1
   
if ($first_day >= 1 && $first_day <= 4)
       
$isonumber++;
    else if (
$number == 0)
       
$isonumber = week_isonumber(mktime(0, 0, 0, 12, 31, $year - 1));

    if (
$isonumber == 53 && ($last_day == 1 || $last_day == 2 || $last_day == 3))
       
$isonumber = 1;

    return
sprintf("%02d", $isonumber);
}
?>
up
6
dgudgeon at example dot com
12 years ago
If moving from date() to strftime() to support additional languages, you may miss the ordinal suffix format option date('S'). Workaround this by adding an extra modifier (%O).

<?php
function my_strftime ($format, $timestamp)
{
   
$format = str_replace('%O', date('S', $timestamp), $format);   
    return
strftime($format, $timestamp);
}
?>
up
5
Lemmi
13 years ago
Why not use utf8_encode to fix problems with letters in ISO-8859-1 and charset set to UTF-8?

For example:
<?php

setlocale
(LC_TIME, "de_DE");
echo
utf8_encode(strftime('%B')); // Output e.g.: März

?>
up
2
Chris
12 years ago
Sometimes, you want Jan 1 to be week 1 and weeks to begin on Sunday. Here's a way to use strftime U format character to follow this convention:
<?php
$month
= 5; $year = 2012; echo "Week #'s in May 2012: ";
$week_num_correction = strftime('%U', mktime(0,0,0,1,1,$year)) === '00' ? 1 : 0;
$week_numbers = range(strftime('%U', mktime(0,0,0,$month,1,$year)) + $week_num_correction, strftime('%U', mktime(0,0,0,$month+1,0,$year)) + $week_num_correction);
foreach(
$week_numbers as $week_number) echo "$week_number ";
?>
displays: Week #'s in May 2012: 18 19 20 21 22
up
1
chris at ocproducts dot com
7 years ago
Displaying hours in 12 hour clock...

%I = Cross-platform, padded with leading zero
%-I = Not on Windows, no padding
%#I = Windows only, no padding

Linux and MacOS confirmed to behave the same.
up
4
szilagyigabor at yahoo dot com
14 years ago
This is that worked with UTF-8 encoding on Linux server, with right accents:
<?php
setlocale
(LC_ALL, 'hu_HU.UTF8');
echo(
strftime('%Y. %B %d. %A'));
?>

Output is:
2009. november 02. hétfő

Also, this one can be used, if not utf-8 preferred:
<?php
setlocale
(LC_ALL, 'hu_HU.ISO8859-2');
?>

UTF-8 is not supported on windows platforms, so there the iconv workaround must be used:
<?php
setlocale
(LC_ALL, 'hun_hun');
echo(
iconv('ISO-8859-2', 'UTF-8',strftime('%Y. %B %d. %A')));
?>

The output is the same as before. Note that, the iconv first parameter is ISO-8859-2 not ISO-8859-1, because the locale is hungarian which uses 8859-2 codepage as default. It is needed for the right accents.

If you want use the same code for Windows and Linux platforms, the second one is the right option (the iconv trick), but the locale configuration must be different (Linux: hu_HU, windows: hun_hun), but in that case the UTF8 tag is not needed for the Linux config.
up
2
fmaz008 at gmail dot com
12 years ago
The example of the workarround for the %e modifier is a bit complex. Sometime you might want to prefer a simple ltrim():

<?php
ltrim
(strftime('%d', $time), '0');
?>
up
2
Josue R.
16 years ago
Here's a simple version for date formating i use between displaying in HTML and converting back to MYSQL format:

<?php
function format_date($original='', $format="%m/%d/%Y") {
   
$format = ($format=='date' ? "%m-%d-%Y" : $format);
   
$format = ($format=='datetime' ? "%m-%d-%Y %H:%M:%S" : $format);
   
$format = ($format=='mysql-date' ? "%Y-%m-%d" : $format);
   
$format = ($format=='mysql-datetime' ? "%Y-%m-%d %H:%M:%S" : $format);
    return (!empty(
$original) ? strftime($format, strtotime($original)) : "" );
}
?>

example (in HTML or webapp):
[grab from database]...
$dbase_stored_date = "2007-03-15";
$display_html_date = format_date($dbase_stored_date);
... displays as "03/15/2007"

example (saving form via on POST/GET):
$update_date = format_date($_POST['display_html_date'], 'mysql-date');
// converts back to '2007-03-15'
.... [your mysql update here]

Don't forget to sanitize your POST/GET's   =)
up
3
eljaunis at gmail dot com
15 years ago
This is what worked in my case:

<?php
    setlocale
(LC_ALL, 'es_ES').': ';
    echo
iconv('ISO-8859-1', 'UTF-8', strftime('%A %d de %B de %Y', time()));
   
?>

it displays: miércoles 22 de octubre de 2008
up
3
jjarsater at gmail dot com
14 years ago
<?php
// Date string
$timestamp     =     strftime("%Y-%m-%d %H:%M:%S %Y");

// From this string ($timestamp) can we print
echo strftime("%a %d %b %H:%M:%S %Y", strtotime($timestamp))."<br/>";
echo
strftime("%a %d %b %H:%M", strtotime($timestamp))."<br/>";
echo
strftime("%Y-%m-%d %H:%M:%S", strtotime($timestamp))."<br/>";
echo
strftime("%Y-%m-%d %H:%M", strtotime($timestamp))."<br/>";
echo
strftime("%Y-%m-%d", strtotime($timestamp))."<br/>";
echo
strftime("%a %d %b %Y", strtotime($timestamp))."<br/>";

/*And it will output

Wed 20 May 15:53:40 2009
Wed 20 May 15:53
2009-05-20 15:53:40
2009-05-20 15:53
2009-05-20
Wed 20 May 2009

*/
?>
up
1
neo at gothic-chat d0t de
19 years ago
To get a RFC 850 date (used in HTTP) of the current time:

gmstrftime ("%A %d-%b-%y %T %Z", time ());

This will get for example:
Friday 25-Jun-04 03:30:23 GMT

Please note that times in HTTP-headers _must_ be GMT, so use gmstrftime() instead of strftime().
up
1
lichihwu at gmail dot com
9 years ago
strftime() will get local time using timezone setting from date_default_timezone_set, then send format and converted tm structure to strftime() system call.

So it will output time stamp string ("%s" format string) with timezone converted tm structure, and it will be wrong unless you set  the same time zone with your machine.
up
2
eric dot brison at anakeen dot com
10 years ago
strftime not format microsecond (decimal part of seconds).
This function add '%f' key in format to render microsecond (6 digits) also.

<?php
/**
* @param string $format strftime format
* @param float $microtime time with microsecond
* @return string
*/
function strftimeu($format, $microtime)
{
    if (
preg_match('/^[0-9]*\\.([0-9]+)$/', $microtime, $reg)) {
       
$decimal = substr(str_pad($reg[1], 6, "0"), 0, 6);
    } else {
       
$decimal = "000000";
    }
   
$format = preg_replace('/(%f)/', $decimal, $format);
    return
strftime($format, $microtime);
}
?>

Example :
<?php
$now
=microtime(true);
printf("REF:%s\n",$now );
printf("FMT:%s\n", strftimeu('%H:%M:%S.%f', $now));
?>

Results are :
REF:1393937303.6615
FMT:13:48:23.661500
FMT:13h 48min 23s 661500µs

Note : Here the decimal part of microtime is on 4 digits due to default precision
up
1
jerome dot place at free dot fr
16 years ago
Here is a function to convert dates before 1970, very useful if you are still using php 4 (it is supported in php5) :

<?php
# convert a date to special format
# $date is like 2000-01-01 00:00:00
# $format : refer to strftime function
function convert_date($date,$format) {   
    if(
$date=='0000-00-00 00:00:00' OR $date=='0000-00-00' OR $date=='' OR $date==NULL) {
        return
'';
    }
    else {
       
$year=substr($date,0,4);
        if(
phpversion() < 5.0 AND $year < 1970) {
           
           
$new_date=substr_replace($date,'1980',0,4); # we replace the year by a year after 1970       
           
$new_format=eregi_replace('%a|%A|%u','',$format); # we remove days information from the format because they would be wrong
           
$new_date=strftime($new_format,strtotime($new_date)); # we convert the date
           
$new_date=eregi_replace('1980',$year,$new_date); # we put back the real year
           
return $new_date;
        }
        else {
            return
strftime($format,strtotime($date));
        }
    }
}
?>
up
2
denis at spiralsolutions dot com
17 years ago
(in addition to Andy's post)
To get a RFC 2822 date (used in RSS) of the current local time :

echo strftime ("%a, %d %b %Y %H:%M:%S %z") ;

Note: option %z / %Z - work different on Windows platform, for example
output of this code line can be:
Thu, 02 Nov 2006 09:54:59 Jerusalem Standard Time (on Windows)
Thu, 02 Nov 2006 09:54:59 +0200                   (on Linux)

[red. It is much smarter to use date(DATE_RSS); here]
up
2
Jon Keating
18 years ago
Under windows if you are using Japanese version, you must use the following code:

setlocale(LC_ALL, "Japanese_Japan.20932") for EUC
setlocale(LC_ALL, "Japanese_Japan.932") for SJIS

I found the following page that helped me with this issue:
http://moodle.org/mod/forum/discuss.php?d=8329
up
1
Chad
14 years ago
On the Linux server I'm using, strftime() also accepts a "-" option to request no padding:

<?php
$ts
= strtotime("4 Nov 2009");
echo
strlen(strftime("%-e", $ts)), "\n"; // "1" (no padding)
echo strlen(strftime("%e", $ts)), "\n"; // "2" (space padded)
?>
up
0
aimendrikonan at gmail dot com
3 years ago
// To set french date format

public function date_chaine($date){

        if($date==NULL){ $date = date('Y-m-d');}
        setlocale(LC_ALL, 'fr_FR').': ';
        return strftime( "%A %d %B %Y" , strtotime($date));
    }

/*
    return this Mercredi 16 septembre 2020
*/
up
0
Marc17
6 years ago
For Windows : this function return the ISO 8601 week number of timestamp.

function week_number_ISO8601($ts_date=0) {
    //See https://fr.wikipedia.org/wiki/ISO_8601#Num.C3.A9ro_de_semaine
    if ($ts_date==0) $ts_date=time();
    $n_w_th_ts_date=strftime('%w',$ts_date);
    $ts_thursday=($n_w_th_ts_date==0)?($ts_date-3*24*3600):($ts_date-($n_w_th_ts_date-4)*24*3600);
    $n_ts_thursday=strftime('%j',$ts_thursday);
    $w_n_iso=1+(int)(($n_ts_thursday-1)/7);
    return sprintf("%02d",$w_n_iso);
}
up
0
denis at ibresource dot ru
9 years ago
%p and %P replaced to '' in ru and other locales so 20:10 in %I:%M %p will be 08:10 in russian (without pm)
up
0
Michael Z.
14 years ago
This is so simple it has to be found in one of all the comments on all those different time functions. But since I didn't find it, here it is: Use this to convert between different time formats:

<?PHP
if (!function_exists('convertTime')) {
 
/** Converts time strings from one format into another using
   *  PHP formats.
   *
   *  @param String $dformat Format to convert to
   *  @param String $sformat Format to convert from, e.g. format
   *      of $ts
   *  @param String $ts Time string to be converted
   *  @return String Supplied time translated to the format specified
   *    in $dformat
   */
 
function convertTime($dformat,$sformat,$ts) {
   
extract(strptime($ts,$sformat));
    return
strftime($dformat,mktime(
                                 
intval($tm_hour),
                                 
intval($tm_min),
                                 
intval($tm_sec),
                                 
intval($tm_mon)+1,
                                 
intval($tm_mday),
                                 
intval($tm_year)+1900
                               
));
  }
}

/*
* And for the test....
*/
echo convertTime('%Y-%m-%d','%d.%m.%Y','27.11.2009');
?>

This should print "2009-27-11".

I did not put much effort in this code. The task also seems "too simple to be neccessary". But as I said, I didn't find anything to help me with this.

Cheers,

Michael Z
up
0
buana95 at yahoo dot com
15 years ago
For windows user:

If you unsuccessfully change date/time format to your locale country using xx_XX format, try using XXX format or ISO-639 country codes format.

See complete list for ISO-639 here: http://www.w3.org/WAI/ER/IG/ert/iso639.htm

For example:

<?php
setlocale
(LC_ALL, 'IND');
echo
strftime("Today in Indonesia is %A");
?>
up
0
nielsvan den berge at hotmail dot com
16 years ago
A small function to get the first weekday of the month.
For example the first monday of the month, or the first friday, etc.

<?php 
 
/**
   *
   *  Gets the first weekday of that month and year
   *
   *  @param  int   The day of the week (0 = sunday, 1 = monday ... , 6 = saturday)
   *  @param  int   The month (if false use the current month)
   *  @param  int   The year (if false use the current year)
   *
   *  @return int   The timestamp of the first day of that month
   *
   **/ 
 
function get_first_day($day_number=1, $month=false, $year=false)
  {
   
$month  = ($month === false) ? strftime("%m"): $month;
   
$year   = ($year === false) ? strftime("%Y"): $year;
   
   
$first_day = 1 + ((7+$day_number - strftime("%w", mktime(0,0,0,$month, 1, $year)))%7);
 
    return
mktime(0,0,0,$month, $first_day, $year);
  }

// this will output the first wednesday of january 2007 (wed 03-01-2007)
echo strftime("%a %d-%m-%Y", get_first_day(3, 1, 2007));
?>
up
0
ma
16 years ago
note, that for some languages you MUST set LC_ALL instead of LC_TIME.

note that you further have to explicitly define your output-encoding (default is ISO-8859-1 [which makes problems for some languages])!

at least i expirienced this behaviour on a german WinXP-PHP4 environment:

<?php

// does not work - gives question marks:
setlocale(LC_TIME, 'RUS'); // ISO Alpha-3 is supported by xp
echo strftime('%A', time());

?>

<?php

// DOES work:
header('Content-Type: text/html; charset=UTF-8'); // you could also use another charset here if iconv isn't installed on your system.

echo setlocale(LC_ALL, 'RUS').': ';
echo
iconv('windows-1251', 'UTF-8', strftime('%A', time()))."\n";

?>
up
0
jw at jwscripts dot com
18 years ago
The following function implements the conversion specifiers which are not supported on Win32 platforms:

(Note: the specifiers %V, %G and %g can be implemented using other functions described in this section)

<?php

function strftime_win32($format, $ts = null) {
    if (!
$ts) $ts = time();

   
$mapping = array(
       
'%C' => sprintf("%02d", date("Y", $ts) / 100),
       
'%D' => '%m/%d/%y',
       
'%e' => sprintf("%' 2d", date("j", $ts)),
       
'%h' => '%b',
       
'%n' => "\n",
       
'%r' => date("h:i:s", $ts) . " %p",
       
'%R' => date("H:i", $ts),
       
'%t' => "\t",
       
'%T' => '%H:%M:%S',
       
'%u' => ($w = date("w", $ts)) ? $w : 7
   
);
   
$format = str_replace(
       
array_keys($mapping),
       
array_values($mapping),
       
$format
   
);

    return
strftime($format, $ts);
}

?>
up
-1
Uwe at Familie-Loyal dot de
11 years ago
more fixed Problems while uing strftime in win32-systems.

        function strftime_win32($format, $ts = null) {
                if (!$ts) $ts = time();
       
                $mapping = array(
                                '%C' => sprintf("%02d", date("Y", $ts) / 100),
                                '%D' => '%m/%d/%y',
                                '%e' => sprintf("%' 2d", date("j", $ts)),
                                '%h' => '%b',
                                '%n' => "\n",
                                '%r' => date("h:i:s", $ts) . " %p",
                                '%R' => date("H:i", $ts),
                                '%t' => "\t",
                                '%T' => '%H:%M:%S',
                                '%u' => ($w = date("w", $ts)) ? $w : 7
                );
                $format = str_replace(
                                array_keys($mapping),
                                array_values($mapping),
                                $format
                );
               
                if($format=='%V' or $format=='%G' or $format=='%g'){
                        // When strftime("%V") fails, some unoptimized workaround
                        //
                        // http://en.wikipedia.org/wiki/ISO_8601 : week 1 is "the week with the year's first Thursday in it (the formal ISO definition)"

                       
                        $year = strftime("%Y", $ts);
                        $isoyear=$year;
                       
                        $first_day = strftime("%w", mktime(0, 0, 0, 1, 1, $year));
                        $last_day = strftime("%w", mktime(0, 0, 0, 12, 31, $year));
                       
                        $number = $isonumber = strftime("%W", $ts);
                       
                        // According to strftime("%W"), 1st of january is in week 1 if and only if it is a monday
                        if ($first_day == 1) {
                                $isonumber--;
                        }
                       
                        // 1st of january is between monday and thursday; starting (now) at 0 when it should be 1
                        if ($first_day >= 1 && $first_day <= 4){
                                $isonumber++;
                                $isoyear=$year;
                        }elseif ($number == 0){
                                $isonumber = mktime(0, 0, 0, 12, 31, $year - 1);
                                $isoyear=$year;
                        }
                        if ($isonumber == 53 && ($last_day == 1 || $last_day == 2 || $last_day == 3)){
                                $isonumber = 1;
                                $isoyear=$year+1;
                        }
                        if ($format=='%V') {
                                return sprintf("%02d", $isonumber);
                        }elseif ($format=='%G'){
                                return sprintf("%04d", $isoyear);
                        }elseif ($format=='%g'){
                                return substr(sprintf("%04d", $isoyear),-2);
                        }
                       
                               
                }else{
                        return strftime($format, $ts);
                }
        }
up
-1
emanuelis at gmail
5 years ago
Linux locales have alt_mon  values for months and php's strftime() has an undocumented format string %OB to get these values.

<?php
setlocale
(LC_ALL, "lt_LT.UTF8");

for (
$i = 1; $i <= 12; $i++) {
echo
strftime("%B", strtotime("2018-$i-01"))." ";
}
//outputs: sausio vasario kovo balandžio gegužės birželio liepos rugpjūčio rugsėjo spalio lapkričio gruodžio
echo "\n";

for (
$i = 1; $i <= 12; $i++) {
echo
strftime("%OB", strtotime("2018-$i-01"))." ";
}
//outputs: sausis vasaris kovas balandis gegužė birželis liepa rugpjūtis rugsėjis spalis lapkritis gruodis

?>
up
-1
chris at ocproducts dot com
7 years ago
Displaying days of month...

%d = Cross-platform, padded with leading zero
%e = Not on Windows, padded with leading space
%-d = Not on Windows, no padding
%#d = Windows only, no padding

Linux and MacOS confirmed to behave the same.
up
-1
Anonymous
5 years ago
If you get wrong characters / encoding, use .utf8 notion after your locale, like this: setlocale(LC_TIME, 'sk_SK.utf8');
up
-1
dosergio at gmail dot com
7 years ago
/*
     Date localized. (date + lo) = datelo
     @param $str = date string format
     @param optional $locale = desired locale, depends on presence in system. Defaults to en_US
     @param optional $time = If needs a specific time, and not current.

     @returns localized translation.

     usage example:  datelo( 'd-M-Y', 'pt_BR') internally changes to '%e-%b-%G' and returns "4-Dez-2016"  (Dezembro is Portuguese word)

    NOTE: Flags prohibited in this version:  "z" and "n", will cause to return the 'date' function version, with no translation!
*/

function datelo( $str, $locale='en_US', $time=null){

  if( $time === null){  $time = time(); }
  
  if ( preg_match("/[DlFM]/", $str) && ! preg_match("/[nz]/",  $str)){
    setlocale(LC_ALL, $locale);
    $dict = array();
    $dict['d'] = '%d';
    $dict['D'] = '%a';
    $dict['j'] = '%e';
    $dict['l'] = '%A';
    $dict['N'] = '%u';
    $dict['w'] = '%w';
    $dict['F'] = '%B';
    $dict['m'] = '%m';
    $dict['M'] = '%b';
    $dict['Y'] = '%G';
    $dict['g'] = '%l';
    $dict['G'] = '%k';
    $dict['h'] = '%I';
    $dict['H'] = '%H';
    $dict['i'] = '%M';
    $dict['s'] = '%S';
    $dict['S'] = ' '; //removes English sufixes th rd etc.
    $dict[' '] = ' ';
    $dict['-'] = '-';
    $dict['/'] = '/';
    $dict[':'] = ':';
    $dict[','] = ',';

    $chars = preg_split("//", $str);
    $nstr = '';

    foreach ($chars as $c){
      if ($c){ //skip empties
         $nstr .= $dict[$c];
      }
    }

    return strftime( $nstr);    

  }else{ // not localized

    return date( $str, $time);

  }
}
up
-3
alexbrtn@gmail dot com
10 years ago
{--}, it is replaced on "today" or "yesterday"
up
-3
dapikk[at]gmail[dot]com
15 years ago
I had a need to subtrackt an older time from current time to get the time between.
Example: If one has worked from 2009-03-16 11:33:54 to 2009-03-16 12:01:54 then he has worked X hours,minutes and seconds. I tried to find that X. And so - one solution would be:
<?php
$start_date
= strtotime("2009-03-16 11:33:54"); //start date from database - date("Y-m-d H:i:s") made as UNIX timestamp
$end_date = strtotime("2009-03-16 12:01:54"); //end date from database - date("Y-m-d H:i:s") made as UNIX timestamp
$ajavahe = $end_date - $start_date;
$time_between = gmstrftime('%Hh %Mm %Ss', $ajavahe); //gmstrftime() deals with different timezones correctly. (If in example you would be situated in Estonia and you would use strftime() you get wrong answer off by 2 hrs, because timezone is GMT+2 - with gmstrftime() comes right answer.)

echo 'You have worked: '.$time_between;
?>
Hope that this one makes someones life easier :D
up
-11
khaled dot ataia at gmail dot com
15 years ago
for Arabic

<?php
setlocale
(LC_ALL,'ar');
echo
strftime('%A %d %B %Y');
?>
up
-5
anton at zebooka dot com
6 years ago
This function outputs incorrect timezone.

PHP 7.1.14 (cli) (built: Feb  2 2018 08:42:59) ( NTS )

We have changed timezone several times in Russia, Novosibirsk:

$ zdump -v /usr/share/zoneinfo/Asia/Novosibirsk | tail -n10
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Oct 30 19:59:59 2010 UTC = Sun Oct 31 02:59:59 2010 +07 isdst=1
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Oct 30 20:00:00 2010 UTC = Sun Oct 31 02:00:00 2010 +06 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Mar 26 19:59:59 2011 UTC = Sun Mar 27 01:59:59 2011 +06 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Mar 26 20:00:00 2011 UTC = Sun Mar 27 03:00:00 2011 +07 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Oct 25 18:59:59 2014 UTC = Sun Oct 26 01:59:59 2014 +07 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Oct 25 19:00:00 2014 UTC = Sun Oct 26 01:00:00 2014 +06 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Jul 23 19:59:59 2016 UTC = Sun Jul 24 01:59:59 2016 +06 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Sat Jul 23 20:00:00 2016 UTC = Sun Jul 24 03:00:00 2016 +07 isdst=0
/usr/share/zoneinfo/Asia/Novosibirsk  Mon Jan 18 03:14:07 2038 UTC = Mon Jan 18 10:14:07 2038 +07 isdst=0

Incorrect:

php > echo strftime('%Y-%m-%d %H:%M:%S %z', strtotime("2015-11-15"));
2015-11-15 00:00:00 +0700

Correct:
php > echo date('Y-m-d H:i:s O', strtotime("2015-11-15"));
2015-11-15 00:00:00 +0600
To Top