J'ai un travail WordPress qui envoie un courrier électronique périodiquement et enregistre l'horodatage lorsqu'il a été envoyé en tant qu'option. J'aimerais afficher une date sur une page de paramètres. Quelque chose comme, "Le dernier email a été envoyé sur 'x'". Je suis sur la côte ouest des États-Unis, nous avons donc sept heures de retard sur l'heure UTC.
Ma sortie attendue de date_i18n (), en lui donnant l'horodatage, serait une date formatée localement avec un ajustement de sept heures à partir de l'heure UTC. Cependant, il retourne l'heure en UTC. Même essayer d’obtenir l’heure actuelle ne retourne pas ce que je pense être la sortie attendue.
Par exemple: echo date_i18n('F d, Y H:i');
génère le 5 avril 2013 à 11h36 comme prévu, mais echo date_i18n('F d, Y H:i',time());
affiche le 05 avril 2013 à 18:36.
Est-ce intentionnel? Comment puis-je retourner une date formatée localement à partir d'un horodatage préexistant? Merci pour toute aide.
Je sais que j'ai trois mois de retard, mais la fonction que vous voulez ici est WordPress ' get_date_from_gmt()
.
La fonction accepte une date GMT/UTC au format Y-m-d H:i:s
en tant que premier paramètre et le format de date souhaité en tant que second paramètre. Votre date sera convertie dans le fuseau horaire local défini dans l'écran Paramètres.
Exemple d'utilisation:
echo get_date_from_gmt( date( 'Y-m-d H:i:s', $my_unix_timestamp ), 'F j, Y H:i:s' );
Du codex :
current_time ('timestamp') doit être utilisé à la place de time () pour renvoyer l'heure locale du blog. Dans WordPress, l'heure () de PHP retournera toujours l'heure UTC et revient à appeler current_time ('timestamp', true).
Essaye ça:
define( 'MY_TIMEZONE', (get_option( 'timezone_string' ) ? get_option( 'timezone_string' ) : date_default_timezone_get() ) );
date_default_timezone_set( MY_TIMEZONE );
echo date_i18n('F d, Y H:i', 1365194723);
Ceci définit la date par défaut PHP sur l'option timezone_string de WP, si elle est disponible, pour la durée du script.
date_i18n($format, $timestamp)
se formate en fonction des paramètres régionaux, mais pas du fuseau horaire. get_date_from_gmt($datestring, $format)
se présente en fonction du fuseau horaire, mais pas des paramètres régionaux. Pour obtenir un formatage conforme au fuseau horaire et à la locale, voici ce que je fais:
function local_date_i18n($format, $timestamp) {
$timezone_str = get_option('timezone_string') ?: 'UTC';
$timezone = new \DateTimeZone($timezone_str);
// The date in the local timezone.
$date = new \DateTime(null, $timezone);
$date->setTimestamp($timestamp);
$date_str = $date->format('Y-m-d H:i:s');
// Pretend the local date is UTC to get the timestamp
// to pass to date_i18n().
$utc_timezone = new \DateTimeZone('UTC');
$utc_date = new \DateTime($date_str, $utc_timezone);
$timestamp = $utc_date->getTimestamp();
return date_i18n($format, $timestamp, true);
}
Exemple de programme:
$format = 'F d, Y H:i';
$timestamp = 1365186960;
$local = local_date_i18n($format, $timestamp);
$gmt = date_i18n($format, $timestamp);
echo "Local: ", $local, " UTC: ", $gmt;
Sortie pour le fuseau horaire de Los Angeles:
Locale: 05 avril 2013 11:36 UTC: 05 avril 2013 18:36
DateTimeZone
docs in php.netDateTime
docs in php.net, y compris setTimestamp
, getTimestamp
et format
date_i18n
docsAjouter un décalage horaire à votre horodatage.
$offset = get_option( 'gmt_offset' ) * HOUR_IN_SECONDS;
return date_i18n( get_option( 'date_format' ), $ts + $offset );
ou mieux;
$tz = new DateTimeZone( get_option( 'timezone_string' ) );
$offset_for_that_time = timezone_offset_get ( $tz , new DateTime("@{$ts}") );
return date_i18n ( get_option( 'date_format' ), $ts + offset_for_that_time );
C'est ce qui semble fonctionner sur ma machine (aucun des autres éléments n'a fonctionné):
$tz = new DateTimeZone(get_option('timezone_string'));
$dtz = new DateTimeZone('GMT');
foreach($posts as $key => $post){
$gmt_date = DateTime::createFromFormat('Y-m-d H:i:s', $post->PostDateGMT, $dtz);
$gmt_date->setTimeZone($tz);
$posts[$key]->PostDateGMT = $gmt_date->format('Y-m-d H:i:s');
}
Code original: https://www.simonholywell.com/post/2013/12/convert-utc-to-local- time/
Il n'utilise pas date_l18n()
mais je suppose qu'on pourrait l'utiliser plus tard ...
J'ai créé une fonction well-document qui convertit une chaîne date-heure au format UTC en une jolie chaîne date-heure dans la langue, le format et le fuseau horaire appropriés. N'hésitez pas à le copier.
Par exemple, transmettre "2019-05-30 18:06:01"
(en UTC) renverrait "Maggio 30, 2019 10:06 am"
.
/**
* Given a string with the date and time in UTC, returns a pretty string in the
* configured language, format and timezone in WordPress' options.
*
* @param string $utc_date_and_time
* e.g: "2019-05-30 18:06:01"
* This argument must be in UTC.
* @return string
* e.g: "Maggio 30, 2019 10:06 am"
* This returns a pretty datetime string in the correct language and
* following the admin's settings.
*/
function pretty_utc_date( string $utc_date ): string {
if (! preg_match( '/^\d\d\d\d-\d\d-\d\d \d\d:\d\d:\d\d$/', $utc_date ) ) {
/* I have not tested other formats, so only this one allowed. */
throw new InvalidArgumentException( "Expected argument to be in YYYY-MM-DD hh:mm:ss format" );
}
$date_in_local_timezone = get_date_from_gmt( $utc_date );
/* $date_in_local_timezone is now something like "2019-05-30 10:06:01"
* in the timezone of get_option( 'timezone_string' ), configured in
* WordPress' general settings in the backend user interface.
*/
/* Unfortunately, we can't just pass this to WordPress' date_i18n, as that
* expects the second argument to be the number of seconds since 1/Jan/1970
* 00:00:00 in the timezone of get_option( 'timezone_string' ), which is not the
* same as a UNIX Epoch timestamp, which is the number of seconds since
* 1/Jan/1970 00:00:00 GMT. */
$seconds_since_local_1_jan_1970 =
(new DateTime( $date_in_local_timezone, new DateTimeZone( 'UTC' ) ))
->getTimestamp();
// e.g: 1559210761
/* Administrators can set a preferred date format and a preferred time
* format in WordPress' general settings in the backend user interface, we
* need to retrieve that. */
$settings_format = get_option( 'date_format' ) . ' '. get_option( 'time_format' );
// $settings_format is in this example "F j, Y g:i a"
/* In this example, the installation of WordPress has been set to Italian,
* and the final result is "Maggio 30, 2019 10:06 am" */
return date_i18n( $settings_format, $seconds_since_local_1_jan_1970 );
}
get_date_from_gmt
docsDateTimeZone
docs in php.netDateTime
docs in php.net, y compris getTimestamp
date_i18n
docsdate_default_timezone_set( 'UTC' );
quel que soit le fuseau horaire sélectionné par l'administrateur dans l'interface utilisateur. Gardez cela à l'esprit lors de la détermination du comportement des fonctions intégrées PHP. Voir date_default_timezone_set
docs sur php.net.