- Сколько прошло времени с указанной даты
- Операции с датами и временем Unixtime в PHP
- Получение временных меток и дат
- Число дня недели
- Числа месяца
- Текущий месяц:
- Преведущий месяц:
- Следующий месяц:
- Число дней в текущем месяце
- Порядковый номер недели
- Число дней в текущем году
- Текущий квартал
- Арифметические операции
- Прибавить к дате 10 секунд
- Прибавить к дате 10 минут
- Прибавить к дате 1 час
- Прибавить к дате 1 день
- Прибавить к дате неделю
- Прибавить к дате месяц
- Прибавить к дате год
- Сколько прошло
- Сколько прошло c 8:00
- Сколько прошло c понедельника этой недели
- Сколько прошло c начала года
- Сколько прошло c определённой даты
- Сколько остается
- Сколько остается до 23:00
- Сколько остается до конца недели
- Сколько остается до конца месяца
- Сколько остается до конца года
- Сколько остается до определенной даты
- Время между датами
- Количество часов между датами
- Количество дней между датами
- Количество месяцев между датами
- Комментарии 2
- Другие публикации
- Как определять количество лет, месяцев, дней между датами?
Сколько прошло времени с указанной даты
Вернуть, сколько прошло времени с указанной даты можно через метод DateTime::diff() .
$date = new DateTime('1990-11-05 00:00:00'); echo $date->diff(new DateTime)->format('прошло %d дней %m месяца %y лет'); // прошло 5 дней 2 месяца 29 лет
Функция ниже возвращает время до указанной даты в сокращённом виде.
function time_ago($datetime) < $interval = date_create('now')->diff($datetime); if ($interval->y >= 1) return $interval->y.' лет';> if ($interval->m >= 1) return $interval->m.' месяца';> if ($interval->d >= 1) return $interval->d.' дней';> if ($interval->h >= 1) return $interval->h.' часов';> if ($interval->i >= 1) return $interval->i.' минут';> return $interval->s.' секунд'; > time_ago(new DateTime('1990-11-05')); // 29 лет time_ago(new DateTime('2017-11-05')); // 2 месяца time_ago(new DateTime('2018-01-05')); // 5 дней
Авторизуйтесь, чтобы добавлять комментарии
Операции с датами и временем Unixtime в PHP
Unix-время (англ. Unix time, также POSIX-время) — система описания моментов во времени. Определяется как количество секунд, прошедших с полуночи 1 января 1970 года.
В PHP текущую метку времени возвращает функция time() и функция strtotime(), также с unix-метками работает класс DateTime.
Получение временных меток и дат
Число дня недели
// Понедельник текущей недели: $time = strtotime('this week monday, 00:00'); echo date('d.m.Y H:i', $time); // 17.07.2023 00:00 // Понедельник предыдущий недели: $time = strtotime('previous week monday, 00:00'); echo date('d.m.Y H:i', $time); // 10.07.2023 00:00 // Понедельник следующей недели: $time = strtotime('next monday, 00:00'); echo date('d.m.Y H:i', $time); // 24.07.2023 00:00
Числа месяца
Текущий месяц:
// Первый день текущего месяца: $time = strtotime('first day of this month 00:00'); echo date('d.m.Y H:i:s', $time); // 01.07.2023 00:00:00 // Последний день текущего месяца: $time = strtotime('last day of this month 23:59'); echo date('d.m.Y H:i:s', $time); // 31.07.2023 23:59:00
Преведущий месяц:
// Первый день предыдущего месяца: $time = strtotime('first day of previous month 00:00'); echo date('d.m.Y H:i:s', $time); // 01.06.2023 00:00:00 // Последний день предыдущего месяца: $time = strtotime('last day of previous month 23:59'); echo date('d.m.Y H:i:s', $time); // 30.06.2023 23:59:00
Следующий месяц:
// Первый день следующего месяца: $time = strtotime('first day of next month 00:00'); echo date('d.m.Y H:i:s', $time); // 01.08.2023 00:00:00 // Последний день следующего месяца: $time = strtotime('last day of next month 23:59'); echo date('d.m.Y H:i:s', $time); // 31.08.2023 23:59:00
Число дней в текущем месяце
Порядковый номер недели
Число дней в текущем году
echo date('L') ? 366 : 365; // 365
Текущий квартал
echo intval((date('n') + 2) / 3); // 3
Арифметические операции
Для сложения и вычитания времени можно применить функцию strtotime() или просто работать с секундами:
1 минута | 60 секунд | 10 минут | 600 секунд |
1 час | 3600 секунд | 10 часов | 36000 секунд |
1 день | 86400 секунд | 2 дня | 172800 секунд |
1 неделя | 604800 секунд | 2 недели | 1209600 секунд |
1 месяц | 2629743 секунд | 2 месяца | 5259486 секунд |
1 год | 31556926 секунд | 2 года | 63072000 секунд |
Прибавить к дате 10 секунд
$time = time() + 10; echo date('d.m.Y H:i:s', $time); // 22.07.2023 05:09:35 /* или */ $time = strtotime('+10 seconds', time()); echo date('d.m.Y H:i:s', $time); // 22.07.2023 05:09:35
Прибавить к дате 10 минут
$time = time() + 600; echo date('d.m.Y H:i:s', $time); // 22.07.2023 05:19:25 /* или */ $time = strtotime('+10 minutes', time()); echo date('d.m.Y H:i:s', $time); // 22.07.2023 05:19:25
Прибавить к дате 1 час
$time = time() + 3600; echo date('d.m.Y H:i:s', $time); // 22.07.2023 06:09:25 /* или */ $time = strtotime('+1 hours', time()); echo date('d.m.Y H:i:s', $time); // 22.07.2023 06:09:25
Прибавить к дате 1 день
$time = time() + 86400; echo date('d.m.Y H:i:s', $time); // 23.07.2023 05:09:25 /* или */ $time = strtotime('+1 days', time()); echo date('d.m.Y H:i:s', $time); // 23.07.2023 05:09:25
Прибавить к дате неделю
$time = strtotime('+1 week', time()); echo date('d.m.Y H:i:s', $time); // 29.07.2023 05:09:25
Прибавить к дате месяц
$time = strtotime('+1 month', time()); echo date('d.m.Y H:i:s', $time); // 22.08.2023 05:09:25
Прибавить к дате год
$time = strtotime('+1 year', time()); echo date('d.m.Y H:i:s', $time); // 22.07.2024 05:09:25
Сколько прошло
Сколько прошло c 8:00
$date = date('d.m.Y 08:00'); $diff = time() - strtotime($date); echo round($diff / 3600, 1); // -2,8 часов
Сколько прошло c понедельника этой недели
$time = strtotime('monday'); $diff = time() - $time; echo round($diff / 3600); // 125 часов echo round($diff / 86400, 1); // 5,2 дней
*Дни недели: monday, tuesday, wednesday, thursday, friday, saturday, sunday.
Сколько прошло c начала года
$date = date('01.01.Y 00:00:00'); $diff = time() - strtotime($date); echo intval($diff / 86400); // 202 дней // или echo date('z'); // 202
Сколько прошло c определённой даты
$date = '10.08.2016'; $diff = time() - strtotime($date); echo round($diff / 3600); // 60893 часов echo round($diff / 86400); // 2537 дней
Сколько остается
Сколько остается до 23:00
$time = strtotime(date('d.m.Y 23:00')); $diff = $time - time(); echo round($diff / 3600, 1); // 17,8 часов
Сколько остается до конца недели
$date = strtotime('next sunday, 23:59'); $diff = $date - time(); echo round($diff / 3600); // 43 часов echo round($diff / 86400); // 2 дней
*Дни недели: monday, tuesday, wednesday, thursday, friday, saturday, sunday.
Сколько остается до конца месяца
$time = strtotime(date('Y-m-t 23:59')); $diff = $time - time(); echo round($diff / 3600); // 235 часов echo round($diff / 86400); // 10 дней
Сколько остается до конца года
$time = strtotime(date('Y-12-31 23:59')); $diff = $time - time(); echo round($diff / 3600); // 3907 часов echo round($diff / 86400); // 163 дней
Сколько остается до определенной даты
$date = '10.08.2025'; $diff = strtotime($date) - time(); echo round($diff / 3600); // 17995 часов echo round($diff / 86400); // 750 дней
Время между датами
Количество часов между датами
$date_1 = '01.01.2021 10:00'; $date_2 = '10.03.2021 18:00'; $seconds = abs(strtotime($date_1) - strtotime($date_2)); echo round($seconds / 3600); // 1640
Количество дней между датами
$date_1 = '01.01.2021 10:00'; $date_2 = '10.03.2021 18:00'; $seconds = abs(strtotime($date_1) - strtotime($date_2)); echo round($seconds / 86400, 1); // 68,3
Количество месяцев между датами
$date_1 = strtotime('01.01.2021 10:00'); $date_2 = strtotime('10.03.2021 18:00'); $months = 0; while (strtotime('+1 month', $date_1) < $date_2) < $months++; $date_1 = strtotime('+1 month', $date_1); >$days = round(($date_2 - $date_1) / (60 * 60 * 24)); echo $months . ' месяца, ' . $days . ' дней'; // 2 месяца, 9 дней
Комментарии 2
Специально не поленился и авторизовался, чтобы выразить благодарность авторам сайта, молодцы ребята! Неоднократно на вашем сайте получал именно нужную инфу, у вас все примеры разжеваны, с разными вариантами, не то что где нибудь найдешь вроде то, что тебе нужно и потом полдня думаешь, как под свою задачу это допилить. В данном случае мне нужно было кол-во дней между датами, при чем число должно быть дробным — то есть 3.6 дня, например. У вас нашел, скопировал, и вставил (только имена переменных поменял), все. Именно то, что нужно. И так бывало уже не раз. В общем, спасибо, и обязательно продолжайте в том же духе!
Авторизуйтесь, чтобы добавить комментарий.
Другие публикации
Заголовок Last-Modified помогает оптимизировать загрузку web-страниц и облегчить работу поисковым роботам.
Как определять количество лет, месяцев, дней между датами?
Подскажите, как определять сколько прошло времени(лет, месяцев, дней) между двумя датами. Допустим есть первая дата — 2016.08.16 и вторая — 2010.03.15. Между ними нужно определить период.
Как посчитать количество дней между датами?
У меня возник такой вопрос как можно пасчитать количество дней между датами. Вот у меня есть.
Количество лет, месяцев, дней между датами
Здравствуйте. Может подскажите как вывести количество лет месяцев дней между двумя датами? спасибо.
Возврат кол-ва лет, месяцев, дней, часов, минут, секунд между датами
Нужно написать функцию которая возвращает в виде символьной строки количество лет, месяцев, дней.
$firstDate = '2016.08.16'; $secondDate = '2010.03.15'; $firstDateTimeObject = new DateTime($firstDate); $secondDateTimeObject = new DateTime($secondDate); $delta = $secondDateTimeObject->diff($firstDateTimeObject); echo $delta->format('y'); // года echo $delta->format('m'); // месяца echo $delta->format('d'); // дни
Только ошибка:
Fatal error: Uncaught exception ‘Exception’ with message ‘DateTime::__construct() [datetime.—construct]: Failed to parse time string (2016.08.16) at position 5 (0): Double time specification’ in C:\OpenServer\domains\mysite.local\vkdate.php:5 Stack trace: #0 C:\OpenServer\domains\mysite.local\vkdate.php(5): DateTime->__construct(‘2016.08.16’) #1 thrown in C:\OpenServer\domains\mysite.local\vkdate.php on line 5
$firstDateTimeObject = DateTime::createFromFormat('Y.m.d', $firstDate); $secondDateTimeObject = DateTime::createFromFormat('Y.m.d', $secondDate);
echo $delta->format('%y'); // года echo $delta->format('%m'); // месяца echo $delta->format(%'d'); // дни
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
$t = "2006-09-23T20:27:12+03:00"; $d = strtotime(date("Y", strtotime($t)).'-'.date("n", strtotime($t)).'-'.date("d", strtotime($t))); $days = floor((strtotime(date("Y-m-d")) - $d) / 86400); echo $days; //возвращает 3615(так и должно быть) $firstDate = date("Y-m-d"); $secondDate = $d; //сюда надо как то вставить $d, убрав что-то из переменной, но так чтобы результат $days не изменился $firstDateTimeObject = DateTime::createFromFormat('Y-m-d', $firstDate); $secondDateTimeObject = DateTime::createFromFormat('Y-m-d', $secondDate); $delta = $secondDateTimeObject->diff($firstDateTimeObject); echo $delta->format('%y')."лет
"; // года echo $delta->format('%m')."месяцев
"; // месяца echo $delta->format('%d')."дней
"; // дни ?>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
$t = "2006-09-23T20:27:12+03:00"; $d = date("Y", strtotime($t)).'-'.date("n", strtotime($t)).'-'.date("d", strtotime($t)); $days = floor((strtotime(date("Y-m-d")) - strtotime($d)) / 86400); echo $days; //возвращает 3615(так и должно быть) $firstDate = date("Y-m-d"); $secondDate = $d; $firstDateTimeObject = DateTime::createFromFormat('Y-m-d', $firstDate); $secondDateTimeObject = DateTime::createFromFormat('Y-m-d', $secondDate); $delta = $secondDateTimeObject->diff($firstDateTimeObject); echo $delta->format('%y')."лет
"; // года echo $delta->format('%m')."месяцев
"; // месяца echo $delta->format('%d')."дней
"; // дни
Вычислить количество месяцев и дней между датами
В общем-то не охота писать такой код самому. Как уже имеющими средствами (тем же DateTime).
Рассчитать количество месяцев и дней между двумя датами
Нужна ваша помощь. Необходимо расчитать количество месяц и дней или только количество дней между.
Количество месяцев и дней между двумя датами в четырех ячейках
Помогите пожалуйста переделать макрос. Нужно что бы работал с 1-го по 20-й листы, Данные.
Количество месяцев и дней между двумя датами в четырех ячейках
Помогите пожалуйста переделать макрос. Нужно что бы работал с 1-го по 20-й листы, Данные.