Ответ 1
вы можете использовать strtotime для таких проблем с датой
echo strtotime("last Monday");
Я готовлю запрос для mySQL, чтобы захватить запись с предыдущей недели, но я должен рассматривать недели как понедельник - воскресенье. Я изначально сделал это:
WHERE YEARWEEK(contactDate) = YEARWEEK(DATE_SUB(CURDATE(),INTERVAL 7 DAY))
чтобы узнать, что mySQL рассматривает недели как воскресенье - понедельник. Поэтому вместо этого я разбираю дату начала и окончания php следующим образом:
$i = 0;
while(date('D',mktime(0,0,0,date('m'), date('d')-$i, date('y'))) != "Mon") {
$i++;
}
$start_date = date('Y-n-j', mktime(0,0,0,date('m'), date('d')-($i+7), date('y')));
$end_date = date('Y-n-j', mktime(0,0,0,date('m'), date('d')-($i+1), date('y')));
Это работает - он получает текущую дату недели в понедельник (ходьба назад до понедельника), а затем вычисляет даты предыдущей недели на основе этой даты.
Мой вопрос: есть ли лучший способ сделать это? Просто кажется неряшливым, и я ожидаю, что кто-то там может дать мне более чистый способ сделать это - или, возможно, не потому, что мне нужны понедельник - воскресенье недели.
По-видимому, существует:
$start = date('Y-m-d',strtotime('last monday -7 days'));
$end = date('Y-m-d',strtotime('last monday -1 days'));
Это примерно в миллион раз больше читаемо. Спасибо.
вы можете использовать strtotime для таких проблем с датой
echo strtotime("last Monday");
(дополнение к marvin и Stomped) Также вы можете использовать его таким образом
echo date('Y-m-d',strtotime('-1 Monday')); //last Monday
echo date('Y-m-d',strtotime('-2 Monday')); //two Mondays ago
echo date('Y-m-d',strtotime('+1 Monday')); //next Monday
Ответ Марвина очень изящный, хотя, если вы действительно хотели пойти на производительность, вы могли бы сделать это с небольшой арифметикой. Вы можете получить формулу/метод для преобразования произвольной даты в "дни с некоторой начальной точки" (возможно, 01.01.0000), а затем остальная часть операций будет легкой с этим. Получение дня недели от такого числа так же просто, как вычитание и получение остатка от деления.
Собственно, PHP имел класс Date в своей библиотеке PEAR, который выполнял именно это.
strtotime("previous week Monday")
Понедельник предыдущей недели.
Я должен указать всем читателям, что есть большая проблема с ответом Марвина
Вот уловка Функция "последний понедельник" вернет дату "последний" понедельник. Это будет объяснено так, если сегодня понедельник, то он вернет дату "ПОСЛЕДНИЙ НЕДЕЛЯ" в понедельник, однако если сегодня не понедельник, он вернется "НА ЭТОЙ НЕДЕЛЕ" понедельник Вопрос заключается в просьбе вернуть "последнюю неделю" в понедельник. Поэтому результат будет неправильным, если сегодня не понедельник. Я решил проблему и обернул мой помощник по дате времени Это будет только одна строка после того, как вы включите "ВКЛЮЧИТЬ" класс
$lastWeekMonday = Model_DTHpr:: getLastWeekMonday();
Проверить здесь