PHP 5.6.30 Released



(PHP 5 >= 5.2.0, PHP 7)

DateTimeZone::getOffset -- timezone_offset_getDevuelve el índice de la zona horaria de GMT


Estilo orientado a objetos

public int DateTimeZone::getOffset ( DateTime $datetime )

Estilo por procedimientos

int timezone_offset_get ( DateTimeZone $object , DateTime $datetime )

Esta función devuelve el índice GMT para la fecha/hora especificada en el parámetro datetime. El índice GMT se calcula con la información de la zona horaria contenida en el objeto DateTimeZone que se va a utilizar.



Solamente para el estilo por procedimientos: Un objeto DateTimeZone devuelto por timezone_open()


El objeto DateTime que contiene la fecha/hora desde la que se va a computar el índice.

Valores devueltos

Devuelve el índice de la zona horaria en segundos si tiene éxito o FALSE en caso de error.


Ejemplo #1 Ejemplo de DateTimeZone::getOffset()

// Crear dos objetos de zona horaria, uno para Taipéi (Taiwán) y otro para
// Tokyo (Japón)
$dateTimeZoneTaipei = new DateTimeZone("Asia/Taipei");
$dateTimeZoneJapan = new DateTimeZone("Asia/Tokyo");

// Crear dos objetos DateTime que contendrán la misma fecha Unix, pero
// tendrán diferentes zonas horarias adjuntas.
$dateTimeTaipei = new DateTime("now"$dateTimeZoneTaipei);
$dateTimeJapan = new DateTime("now"$dateTimeZoneJapan);

// Calcular el índice GMT para la fecha/hora contenida en el objeto $dateTimeTaipei,
// pero usando las normas de la zona horaria definidas en Tokyo
// ($dateTimeZoneJapan).
$timeOffset $dateTimeZoneJapan->getOffset($dateTimeTaipei);

// Debería mostrar int(32400) (para fechas después de Sat Sep 8 01:00:00 1951 JST).

add a note add a note

User Contributed Notes 2 notes

Fred Gandt
2 years ago
Procedural Style:

// Don't know where the server is or how its clock is set, so default to UTC
date_default_timezone_set( "UTC" );

// The client is in England where daylight savings may be in effect
$daylight_savings_offset_in_seconds = timezone_offset_get( timezone_open( "BST" ), new DateTime() );

// Do something useful with the number
echo date( "U" ) + $daylight_savings_offset_in_seconds;
skanzow at gmx dot net
5 years ago
A common problem is to format dates and times for XML documents.
The XML standard is defined as follows:

    To specify a time zone, you can either enter a dateTime in UTC time by adding a "Z" behind the time - like this:
    or you can specify an offset from the UTC time by adding a positive or negative time behind the time - like this:

Here is a possible solution in PHP:
if(date_default_timezone_get() == 'UTC') {
$offsetString = 'Z'; // No need to calculate offset, as default timezone is already UTC
} else {
$phpTime = '2002-05-30 09:30:10';
$millis = strtotime($phpTime); // Convert time to milliseconds since 1970, using default timezone
$timezone = new DateTimeZone(date_default_timezone_get()); // Get default system timezone to create a new DateTimeZone object
$offset = $timezone->getOffset(new DateTime($phpTime)); // Offset in seconds to UTC
$offsetHours = round(abs($offset)/3600);
$offsetMinutes = round((abs($offset) - $offsetHours * 3600) / 60);
$offsetString = ($offset < 0 ? '-' : '+')
                . (
$offsetHours < 10 ? '0' : '') . $offsetHours
. ':'
. ($offsetMinutes < 10 ? '0' : '') . $offsetMinutes;
'<startdate>' . date('Y-m-d\TH:i:s', $millis) . $offsetString . '</startdate>'); // This is the correct XML format
To Top