Расчет количества суббот и воскресенья

Как я могу рассчитать количество суббот и воскресенья между двумя датами в php?

Есть ли встроенная функция для этой цели?

Ответ 1

Здесь уже есть связанный с этим вопрос, Рассчитать рабочие дни

Вы можете использовать это для вычитания из 7, чтобы получить выходные дни или аналогичные.

Ответ 2

Я не думаю, что для этого есть встроенная функция, но это должно выполнить задание:

$startTime = START_TIMESTAMP;
$endTime = END_TIMESTAMP;
$time = $startTime;
$count = 0;

while(date('w', $time) != 0) { // 0 (for Sunday) through 6 (for Saturday)
    $time += 86400;
}

while($time < $endTime) {
    $count++;
    $time += 7 * 86400;
}

Ответ 3

Давайте все KISS (Keep It Simple Stupid). Почему это так сложно?

function countWeekendDays($start, $end)
{
    // $start in timestamp
        // $end in timestamp


    $iter = 24*60*60; // whole day in seconds
    $count = 0; // keep a count of Sats & Suns

    for($i = $start; $i <= $end; $i=$i+$iter)
    {
        if(Date('D',$i) == 'Sat' || Date('D',$i) == 'Sun')
        {
            $count++;
        }
    }
    return $count;
   }

Ответ 4

Вы можете рассчитать это математически, как это - на основе ответа Роланда

private function getNumberOfWeekendDays(\DateTimeInterface $startDate, \DateTimeInterface $endDate): int
{
    $startNumber = (int) $startDate->format('N');
    $endNumber = (int) $endDate->format('N');
    $daysBetweenStartAndEnd = $endDate->diff($startDate)->d;

    $weekendDays = (int) (2 * ($daysBetweenStartAndEnd + $startNumber) / 7);
    $weekendDays = $weekendDays - ($startNumber == 7 ? 1 : 0) - ($endNumber == 7 ?  1 :  0);

    return $weekendDays;
}

Ответ 5

<?php
date_default_timezone_set("Europe/Lisbon");
$d1 = new DateTime("2009-06-01"); /* inclusive */
$d2 = new DateTime("2009-07-01"); /* exclusive */

$interval = $d2->diff($d1);
$number_of_days = $interval->format("%d");

$number_of_weekends = $number_of_days / 7;
$remainder = $number_of_days % 7;

if ($remainder >=2 && $d1->format("D") == "Sat")
    $number_of_weekends++;
elseif ($d1->format("w") + $remainder >= 8)
    $number_of_weekends++;

Возможно, я пропустил один в последнем условии, обязательно проверьте его с разными датами начала. (Не стесняйтесь редактировать этот ответ, если вы заметили ошибку).

Ответ 6

для этого нет встроенной функции, но вы можете использовать strtotime для циклов дней

$start = strtotime('2010-01-01');
$end = strtotime('2010-01-09');

function numWeekdays( $start_ts, $end_ts, $day, $include_start_end = false ) {

    $day = strtolower( $day );
    $current_ts = $start_ts;
    // loop next $day until timestamp past $end_ts
    while( $current_ts < $end_ts ) {

        if( ( $current_ts = strtotime( 'next '.$day, $current_ts ) ) < $end_ts) {
            $days++;
        }
    }

    // include start/end days
    if ( $include_start_end ) {
        if ( strtolower( date( 'l', $start_ts ) ) == $day ) {
            $days++;
        }
        if ( strtolower( date( 'l', $end_ts ) ) == $day ) {
            $days++;
        }
    }   

    return (int)$days;

}

echo numWeekDays( $start, $end, 'saturday', false );

Ответ 7

Я искал какое-то время для простого решения, которое сработало и решило написать свое собственное и придумало этот

        $start = date('Y-m-d');
        $end = date('Y-m-d', strtotime($start.' +1 year'));
        $current = $start;
        $count = 0;

        while($current != $end){
            if(date('l', strtotime($current)) == 'Saturday'){
                $count++;
            }

            $current = date('Y-m-d', strtotime($current.' +1 day'));
        };

        echo $count;