(PHP 5 >= 5.5.0, PHP 7, PHP 8)
DateTimeImmutable::setTime — 時刻を設定する
$hour
,$minute
,$second
= 0,$microsecond
= 0指定された時刻を設定した、 新しい DateTimeImmutable オブジェクト を返します。
object
手続き型のみ: date_create() が返す DateTime オブジェクト。 この関数は、このオブジェクトを変更します。
hour
その時刻の時。
minute
その時刻の分。
second
その時刻の秒。
microsecond
その時刻のマイクロ秒。
新しく変更された DateTimeImmutable オブジェクトを返します。失敗した場合に false
を返します.
バージョン | 説明 |
---|---|
7.1.0 | microsecond パラメータが追加されました。 |
例1 DateTimeImmutable::setTime() の例
オブジェクト指向型
<?php
$date = new DateTimeImmutable('2001-01-01');
$newDate = $date->setTime(14, 55);
echo $date->format('Y-m-d H:i:s') . "\n";
$newDate = $date->setTime(14, 55, 24);
echo $date->format('Y-m-d H:i:s') . "\n";
?>
上の例の出力は、 たとえば以下のようになります。
2001-01-01 14:55:00 2001-01-01 14:55:24
例2 範囲を超えた値が親の値に加算される例
<?php
$date = new DateTimeImmutable('2001-01-01');
$newDate = $date->setTime(14, 55, 24);
echo $newDate->format('Y-m-d H:i:s') . "\n";
$newDate = $date->setTime(14, 55, 65);
echo $newDate->format('Y-m-d H:i:s') . "\n";
$newDate = $date->setTime(14, 65, 24);
echo $newDate->format('Y-m-d H:i:s') . "\n";
$newDate = $date->setTime(25, 55, 24);
echo $newDate->format('Y-m-d H:i:s') . "\n";
?>
上の例の出力は以下となります。
2001-01-01 14:55:24 2001-01-01 14:56:05 2001-01-01 15:05:24 2001-01-02 01:55:24