У певних ситуаціях я хочу додати 1 день до значення моєї відформатованої змінної DATETIME:
$start_date = date('Y-m-d H:i:s', strtotime("{$_GET['start_hours']}:{$_GET['start_minutes']} {$_GET['start_ampm']}"));
Який найкращий спосіб це зробити?
Відповіді:
Якщо ви хочете зробити це в PHP:
// replace time() with the time stamp you want to add one day to
$startDate = time();
date('Y-m-d H:i:s', strtotime('+1 day', $startDate));
Якщо ви хочете додати дату в MySQL:
-- replace CURRENT_DATE with the date you want to add one day to
SELECT DATE_ADD(CURRENT_DATE, INTERVAL 1 DAY);
time()на strtotime("{$_GET['start_hours']}:{$_GET['start_minutes']} {$_GET['start_ampm']}").
Існує більше одного способу зробити це за допомогою DateTime, який був представлений в PHP 5.2. На відміну від використання, strtotime()це буде враховувати перехід на літній час та високосний рік.
$datetime = new DateTime('2013-01-29');
$datetime->modify('+1 day');
echo $datetime->format('Y-m-d H:i:s');
// Available in PHP 5.3
$datetime = new DateTime('2013-01-29');
$datetime->add(new DateInterval('P1D'));
echo $datetime->format('Y-m-d H:i:s');
// Available in PHP 5.4
echo (new DateTime('2013-01-29'))->add(new DateInterval('P1D'))->format('Y-m-d H:i:s');
// Available in PHP 5.5
$start = new DateTimeImmutable('2013-01-29');
$datetime = $start->modify('+1 day');
echo $datetime->format('Y-m-d H:i:s');
+2 dayабо +2 days(очевидно, +2 daysце семантично правильніше)
Конструктор DateTime приймає параметр string time. $timeце можуть бути різні речі, він повинен поважати формат дати та часу .
Є кілька допустимих значень як приклади:
'now' (значення за замовчуванням)2017-10-192017-10-19 11:59:592017-10-19 +1dayОтже, у вашому випадку ви можете використовувати наступне.
$dt = new \DateTime('now +1 day'); //Tomorrow
$dt = new \DateTime('2016-01-01 +1 day'); //2016-01-02
strtotimeдля перетворення рядка в позначку часунаприклад:
$time = strtotime($myInput);
$newTime = $time + 86400;
Якщо це лише додавання 1 дня, то використання strtotime знову, ймовірно, надмірне.
date()місцевого часового поясу враховується, який буде дбати про перехід на літній час.
Я пропоную почати використовувати класи Zend_Date із Zend Framework . Я знаю, це трохи нетопично, але мені сподобається такий спосіб :-)
$date = new Zend_Date();
$date->add('24:00:00', Zend_Date::TIMES);
print $date->get();
Ви можете використовувати наступне.
$start_date = date('Y-m-d H:i:s');
$end_date = date("Y-m-d 23:59:59", strtotime('+3 days', strtotime($start_date)));
Ви також можете встановити дні як постійні та використовувати, як показано нижче.
if (!defined('ADD_DAYS')) define('ADD_DAYS','+3 days');
$end_date = date("Y-m-d 23:59:59", strtotime(ADD_DAYS, strtotime($start_date)));
Використання часу запиту сервера для додавання днів. Працюючи, як очікувалося.
25.08.19 => 27.09.19
$timestamp = $_SERVER['REQUEST_TIME'];
$dateNow = date('d/m/y', $timestamp);
$newDate = date('d/m/y', strtotime('+2 day', $timestamp));
Тут "+2 дні", щоб додати будь-яку кількість днів.
Існує більш стислий та інтуїтивно зрозумілий спосіб додати дні до дати php. Не зрозумійте мене неправильно, ці вирази php чудові, але вам завжди потрібно шукати в Google, як з ними поводитися. Я сумую за цим об’єктом автозавершення.
Ось як я люблю розглядати ці справи:
(new Future(
new DateTimeFromISO8601String('2014-11-21T06:04:31.321987+00:00'),
new OneDay()
))
->value();
Для мене це набагато інтуїтивніше, і автозаповнення працює нестандартно. Не потрібно щоразу гуглити рішення.
Як приємний бонус, вам не потрібно турбуватися про форматування отриманого значення, це вже формат ISO8601.
Це бібліотека безе, є кілька прикладів тут .