DateTimeZone::getOffset

timezone_offset_get

(PHP 5 >= 5.2.0, PHP 7)

DateTimeZone::getOffset -- timezone_offset_getВозвращает смещение временной зоны от GMT

Описание

Объектно-ориентированный стиль

public int DateTimeZone::getOffset ( DateTime $datetime )

Процедурный стиль

int timezone_offset_get ( DateTimeZone $object , DateTime $datetime )

Эта функция возвращает смещение от GMT для даты/времени, указанных в параметре datetime. GMT-смещение рассчитывается с помощью информации о временной зоне, содержащейся в используемом объекте DateTimeZone.

Список параметров

object

Только для процедурного стиля: Объект DateTimeZone, возвращаемый timezone_open()

datetime

DateTime, содержащий дату/время, относительно которых вычисляется смещение.

Возвращаемые значения

В случае успеха возвращает смещение временной зоны в секундах или FALSE в случае возникновения ошибки.

Примеры

Пример #1 Пример использования DateTimeZone::getOffset()

<?php
// Создание двух объектов timezone, один для  Тайбэй (Тайвань) и один для
// Токио (Япония)
$dateTimeZoneTaipei = new DateTimeZone("Asia/Taipei");
$dateTimeZoneJapan = new DateTimeZone("Asia/Tokyo");

// Создание двух объектов DateTime которые будут содержать одинаковые метки времени Unix, но
// имеющие различные временные зоны.
$dateTimeTaipei = new DateTime("now"$dateTimeZoneTaipei);
$dateTimeJapan = new DateTime("now"$dateTimeZoneJapan);

// Вычисление смещения от GMT для даты/времени, содержащихся в объекте $dateTimeTaipei,
// но с использованием правил временной зоны, определенных для Токио
// ($dateTimeZoneJapan).
$timeOffset $dateTimeZoneJapan->getOffset($dateTimeTaipei);

// Должен показать int(32400) (для дат после Sat Sep 8 01:00:00 1951 JST).
var_dump($timeOffset);
?>

Коментарии

Автор:
Note that the DateTime parameter has no effect in the result returned by DateTimeZone::getOffset($DateTime), unless, it refers to a DateTime where there is daylight savings in the referenced DateTimeZone.

Ex.:
<?php
$timezone_brl   
= new DateTimeZone('America/Sao_Paulo');
$timezone_eng    = new DateTimeZone('Europe/London');
$timezone_aus    = new DateTimeZone('Australia/Brisbane');

$dateTimes = [
      new 
DateTime()
    , new 
DateTime('now'$timezone_eng)
    , new 
DateTime('now'$timezone_aus)
    , new 
DateTime('now'$timezone_brl)
    , new 
DateTime('2000-06-10'$timezone_brl)
    , new 
DateTime('2000-12-10'$timezone_brl)
    , new 
DateTime('2020-12-10'$timezone_brl)
];

foreach(
$dateTimes as $dateTime)
{
  echo 
"\n" $timezone_brl->getOffset($dateTime);
}
/**
* -10800
* -10800
* -10800
* -10800
* -10800  // No daylight savings in June/2000
* -  7200  // Brazil had daylight savings until 2020
* -10800  // No more daylight savings, so it returns -10800
*/

?>
2022-08-17 23:13:11
http://php5.kiev.ua/manual/ru/datetimezone.getoffset.html
Автор:
int offset does not cover fractional offsets of "rogue" locations such as Nepal etc.
2022-08-25 23:08:44
http://php5.kiev.ua/manual/ru/datetimezone.getoffset.html

    Поддержать сайт на родительском проекте КГБ