日時の切り上げ/切捨て/四捨五入
ceil、floor、roundを使って時間の切り上げ、切捨て、四捨五入
PHP
/**
*
* 日時の切り上げ/切捨て/四捨五入
*
* @param string $date
* @param integer $place 1|10|100|1000|10000|100000
* @param string $math ceil|floor|round
* @return string
*/
function getDateRound($date, $place, $math)
{
list($Y, $m, $d, $H, $i, $s) = explode("-", date('Y-m-d-H-i-s', strtotime($date)));
// 秒(1で1の位、10で秒全体)
if ($place == 1) {
$s = $math($s * 0.1) * 10;
} elseif ($place > 1) {
$s = $math($s * 0.01) * 100;
if ($s > 60) {
$s = 60;
}
}
if ($place > 10) {
$date = date('Y-m-d-H-i-s', mktime($H, $i, $s, $m, $d, $Y));
list($Y, $m, $d, $H, $i, $s) = explode("-", $date);
}
// 分(100で1の位、1000で分全体)
if ($place == 100) {
$i = $math($i * 0.1) * 10;
} elseif ($place > 100) {
$i = $math($i * 0.01) * 100;
if ($i > 60) {
$i = 60;
}
}
if ($place > 1000) {
$date = date('Y-m-d-H-i-s', mktime($H, $i, $s, $m, $d, $Y));
list($Y, $m, $d, $H, $i, $s) = explode("-", $date);
}
// 時間(10000で1の位、100000で時間全体)
if ($place == 10000) {
$H = $math($H * 0.1) * 10;
} elseif ($place > 10000) {
$H = $math($H * 0.01) * 100;
if ($H > 24) {
$H = 24;
}
}
return date('Y-m-d H:i:s', mktime($H, $i, $s, $m, $d, $Y));
}
計算結果
値($place) | ceil | floor | round |
---|---|---|---|
1 | 2025-01-18 14:06:40 | 2025-01-18 14:06:30 | 2025-01-18 14:06:30 |
10 | 2025-01-18 14:07:00 | 2025-01-18 14:06:00 | 2025-01-18 14:06:00 |
100 | 2025-01-18 14:10:00 | 2025-01-18 14:00:00 | 2025-01-18 14:10:00 |
1000 | 2025-01-18 15:00:00 | 2025-01-18 14:00:00 | 2025-01-18 14:00:00 |
10000 | 2025-01-18 20:00:00 | 2025-01-18 10:00:00 | 2025-01-18 10:00:00 |
100000 | 2025-01-19 00:00:00 | 2025-01-18 00:00:00 | 2025-01-18 00:00:00 |