PHP 8.4.3 Released!

The DateTimeZone class

(PHP 5 >= 5.2.0, PHP 7, PHP 8)

Introduction

Representation of time zone.

Class synopsis

class DateTimeZone {
/* Constants */
public const int AFRICA;
public const int AMERICA;
public const int ANTARCTICA;
public const int ARCTIC;
public const int ASIA;
public const int ATLANTIC;
public const int AUSTRALIA;
public const int EUROPE;
public const int INDIAN;
public const int PACIFIC;
public const int UTC;
public const int ALL;
public const int ALL_WITH_BC;
public const int PER_COUNTRY;
/* Methods */
public __construct(string $timezone)
public getName(): string
public getOffset(DateTimeInterface $datetime): int
public getTransitions(int $timestampBegin = PHP_INT_MIN, int $timestampEnd = PHP_INT_MAX): array|false
public static listAbbreviations(): array
public static listIdentifiers(int $timezoneGroup = DateTimeZone::ALL, ?string $countryCode = null): array
}

Predefined Constants

DateTimeZone::AFRICA int

Africa time zones.

DateTimeZone::AMERICA int

America time zones.

DateTimeZone::ANTARCTICA int

Antarctica time zones.

DateTimeZone::ARCTIC int

Arctic time zones.

DateTimeZone::ASIA int

Asia time zones.

DateTimeZone::ATLANTIC int

Atlantic time zones.

DateTimeZone::AUSTRALIA int

Australia time zones.

DateTimeZone::EUROPE int

Europe time zones.

DateTimeZone::INDIAN int

Indian time zones.

DateTimeZone::PACIFIC int

Pacific time zones.

DateTimeZone::UTC int

UTC time zones.

DateTimeZone::ALL int

All time zones.

DateTimeZone::ALL_WITH_BC int

All time zones including backwards compatible.

DateTimeZone::PER_COUNTRY int

Time zones per country.

Changelog

Version Description
8.4.0 The class constants are now typed.

Table of Contents

add a note

User Contributed Notes 1 note

up
-2
Jarmo Troska
1 year ago
Example of converting between timezones using the DateTime and DateTimeZone classes.

Note that PHP will also take care of calculating relevant daylight savings!

<?php

$utc_timezone
= new DateTimeZone("UTC");

$tallinn_timezone = new DateTimeZone("Europe/Tallinn");

// Create a new DateTime object in the UTC format

$datetime = new DateTime("2023-01-01 11:00:00", $utc_timezone);

// Convert the DateTime object to the timezone of Tallinn

$datetime->setTimezone($tallinn_timezone);

// Display the result in the YYYY-MM-DD HH:MM:SS format

echo $datetime->format('Y-m-d H:i:s');

// Returns: 2023-01-01 13:00:00

?>
To Top