Перетворення часових позначок у місцевий час з датою_l18n ()


15

У мене є завдання WordPress cron, яке періодично надсилає електронне повідомлення та зберігає часову позначку, коли воно було надіслано як опцію, і я хотів би відобразити дату на сторінці налаштувань. Щось на кшталт "Останнє повідомлення було надіслано на" x "". Я перебуваю на західному узбережжі США, тому наш час зараз сім годин поза UTC.

Мій очікуваний вихід з date_i18n (), передаючи йому часову позначку, буде локально відформатованою датою з семигодинним регулюванням від UTC. Однак повертає час у UTC. Навіть спроба отримати поточний час не повертає те, що я б вважав очікуваним результатом.

Наприклад: echo date_i18n('F d, Y H:i');результати 05 квітня 2013 р. 11:36, як очікувалося, але echo date_i18n('F d, Y H:i',time());результати 05 квітня 2013 р. 18:36.

Це навмисно? Як я можу повернути локально відформатовану дату з попередньо існуючої позначки часу? Дякуємо за будь-яку допомогу.


Ви встановили часовий пояс у меню Налаштування-> Загальні?
vancoder

Так, до Лос-Анджелеса.
Ендрю Бартель

Відповіді:


31

Я знаю, що я запізнююсь на три місяці, але функція, яку ви хочете тут, є WordPress ' get_date_from_gmt().

Функція приймає дату GMT / UTC у Y-m-d H:i:sформаті в якості першого параметра, а бажаний формат дати - як другий параметр. Він перетворить вашу дату в локальний часовий пояс, як встановлено на екрані налаштувань.

Приклад використання:

echo get_date_from_gmt( date( 'Y-m-d H:i:s', $my_unix_timestamp ), 'F j, Y H:i:s' );


2
Вбивчий спасибі, побачив це спливаюче вікно в моїх сповіщеннях саме зараз. Я переключив його на правильну відповідь.
Ендрю Бартель

1
Я додав конфігурацію дати та часу: echo get_date_from_gmt ( date( 'Y-m-d H:i:s', $my_timestamp ), get_option('date_format') . ' - '. get_option('time_format') );
Nabil Kadimi

@NabilKadimi - це чудове доповнення, але воно все ще не переводить рядок на правильну мову. Дивіться мою відповідь щодо функції, яка враховує всі три налаштовані мови, часовий пояс та формат дати.
Флейм

5

З кодексу :

current_time ('timetamp') слід використовувати замість часу () для повернення місцевого часу блогу. У WordPress час PHP () завжди буде повертати UTC і є таким самим, як виклик current_time ('timetamp', правда).

Спробуйте це:

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);

Це встановлює дату PHP за замовчуванням у параметрі WP timezone_string, якщо вона доступна, на час дії сценарію.


1
Правильно, але що робити, якщо у мене є довільна мітка часу? Скажіть пару днів тому, як мені отримати відрегульований час, а не час UTC?
Ендрю Бартель

це date_i18n('F d, Y H:i', $your_timestamp)не працює?
vancoder

Ні, я навіть спробував це встановити на ванільній WP з 2012 року, лише запустивши цю echo date_i18n('F d, Y H:i',1365194723)заяву у верхній частині index.php, що дає мені UTC, а не час на Західному узбережжі США.
Ендрю Бартель

Ви маєте рацію, схоже, що date_i18n в основному стосується локального форматування дат, а не коригування дати. Я оновив свою відповідь.
vancoder

Так, я сподівався уникнути необхідності встановлювати часовий пояс вручну, але якщо це єдиний спосіб, так і нехай буде. Позначено як відповідь, дякую за допомогу.
Ендрю Бартель

2

date_i18n($format, $timestamp)формати відповідно до місцевості, але не часового поясу. get_date_from_gmt($datestring, $format)формати відповідно до часового поясу, але не за місцем. Для отримання форматування відповідно до часового поясу та місцевості я виконую наступні дії:

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);
}

Приклад програми:

$format = 'F d, Y H:i';
$timestamp = 1365186960;
$local = local_date_i18n($format, $timestamp);
$gmt = date_i18n($format, $timestamp);
echo "Local: ", $local, " UTC: ", $gmt;

Вихідні дані для часового поясу Лос-Анджелеса:

Місцеві: 05 квітня 2013 11:36 UTC: 05 квітня 2013 18:36

Список літератури:


0

Додайте зміщення часового поясу до часової позначки.

$offset = get_option( 'gmt_offset' ) * HOUR_IN_SECONDS;
return date_i18n( get_option( 'date_format' ), $ts + $offset );

або краще;

$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 );

0

Перетворення UTC у рядок у часовому поясі, мові та форматі у параметрах WordPress

Я створив функцію добре документа, яка перетворює рядок дати-часу в UTC у гарний рядок дати-часу у правильній мові, форматі та часовому поясі. Сміливо скопіюйте його.

Наприклад, "2019-05-30 18:06:01"повернення в (за UTC) повернеться "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 );

}

Список літератури:


-1

Це те, що, здається, працює на моїй машині (жоден інший матеріал не працював):

$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');
}

Оригінальний код: https://www.simonholywell.com/post/2013/12/convert-utc-to-local-time/

Це не використовується, date_l18n()але, мабуть, можна було б використовувати його згодом ...

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.