IntlDateFormatter::getTimeZone

datefmt_get_timezone

タイムゾーンを取得する

説明

オブジェクト指向型

public IntlTimeZonefalse IntlDateFormatter::getTimeZone()

手続き型

IntlTimeZonefalse datefmt_get_timezone(IntlDateFormatter $formatter)

タイムゾーンを表す IntlTimeZone オブジェクトを返します。 このオブジェクトで日付や時刻をフォーマットするときに、このタイムゾーンを使います。 IntlCalendarDateTime オブジェクトをこの IntlDateFormatter でフォーマットするときに使うタイムゾーンは、 このメソッドが返すものとなります。フォーマットしようとしているオブジェクトのタイムゾーンではありません。

パラメータ

この関数にはパラメータはありません。

戻り値

IntlTimeZone オブジェクトを返します。 失敗した場合に false を返します。

例1 IntlDateFormatter::getTimeZone の例

<?php

$madrid = IntlDateFormatter::create(NULL, NULL, NULL, 'Europe/Madrid');
$lisbon = IntlDateFormatter::create(NULL, NULL, NULL, 'Europe/Lisbon');

var_dump($madrid->getTimezone());
echo $madrid->getTimezone()->getDisplayName(
        false, IntlTimeZone::DISPLAY_GENERIC_LOCATION, "en_US"), "\n";
echo $lisbon->getTimeZone()->getId(), "\n";
// id は ->getTimezoneId() でも取得できます
echo $lisbon->getTimeZoneId(), "\n";

上の例の出力は以下となります。

object(IntlTimeZone)#4 (4) {
  ["valid"]=>
  bool(true)
  ["id"]=>
  string(13) "Europe/Madrid"
  ["rawOffset"]=>
  int(3600000)
  ["currentOffset"]=>
  int(7200000)
}
Spain Time
Europe/Lisbon
Europe/Lisbon

参考

  • IntlDateFormatter::getTimeZoneId
  • IntlDateFormatter::setTimeZone
  • IntlTimeZone