Только рабочие дни и удалить выходные и праздничные дни в PHP - PullRequest
0 голосов
/ 21 января 2019

Я пытаюсь отформатировать только рабочие дни, удаляя субботу, воскресенье и праздничные дни.

Я нашел эту функцию "function day_holiday ()" в "Stackoverflow" в праздничные дни в моей родной стране.

Я создал этот скрипт на php ниже, насколько мне известно

//-------------------------HOLIDAY--------------
function day_holiday($ano = null){
    if ($ano === null){
        $ano = intval(date('Y'));
    }
    $pascoa     = easter_date($ano);
    $dia_pascoa = date('j', $pascoa);
    $mes_pascoa = date('n', $pascoa);
    $ano_pascoa = date('Y', $pascoa);

    $holiday = array(
        mktime(0, 0, 0, 1,  1,   $ano),
        mktime(0, 0, 0, 4,  21,  $ano),
        mktime(0, 0, 0, 5,  1,   $ano),
        mktime(0, 0, 0, 9,  7,   $ano),
        mktime(0, 0, 0, 10,  12, $ano),
        mktime(0, 0, 0, 11,  2,  $ano),
        mktime(0, 0, 0, 11, 15,  $ano),
        mktime(0, 0, 0, 12, 25,  $ano),

        mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 48,  $ano_pascoa),
        mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 47,  $ano_pascoa), 
        mktime(0, 0, 0, $mes_pascoa, $dia_pascoa - 2 ,  $ano_pascoa), 
        mktime(0, 0, 0, $mes_pascoa, $dia_pascoa     ,  $ano_pascoa),
        mktime(0, 0, 0, $mes_pascoa, $dia_pascoa + 60,  $ano_pascoa),
    );
    sort($holiday);
    return $holiday;
}
//-------------------------HOLIDAY--------------


//-------------SCRIPT-------------
function formatDate($startDate,$days) {

    $holiday = day_holiday();
    foreach ($holiday as $allholiday){

        if($startDate==date('d-m-Y',$allholiday)){
            $newDate=date('d-m-Y', strtotime("+1 days",strtotime($startDate)));
        }else{
            $newDate = date('d-m-Y', strtotime("{$startDate} +{$days} weekdays"));
        }
    }

    return $newDate;
}

$sales = "19-01-2019"; //19 and Saturday is jumping for Monday 21 second
/*
These are some holidays.
01-01-2019
04-03-2019
05-03-2019
19-04-2019
21-04-2019
21-04-2019
01-05-2019
*/

echo "Start: ",date("d-m-Y", strtotime($sales)),"<br />";

echo formatDate($sales, "0");

Проблема устранена только по субботам и воскресеньям.Праздники не убираются.Чего не хватает?Кто-нибудь может мне помочь?Если у вас есть более динамичный скрипт, вы можете опубликовать здесь.

1 Ответ

0 голосов
/ 21 января 2019

Это, вероятно, более надежный способ делать то, что вы хотите. Функция создает объект DateTime из времени начала, затем сравнивает временную метку, чтобы увидеть, если

  1. Он находится в массиве $holiday; или
  2. Это суббота или воскресенье (день недели = 0 или 6)

Если ни одно из этих условий не выполняется, цикл завершается, и возвращается дата. В противном случае дата увеличивается на 1 день, пока не будет найдена дата, соответствующая всем условиям (т. Е. С понедельника по пятницу, а не в праздничные дни).

function formatDate($startDate) {
    $holiday = day_holiday();
    $start = date_create_from_format('d-m-Y H:i:s', $startDate . ' 00:00:00');
    do {
        $ts = (int)$start->format('U');
        $dow = (int)$start->format('w');
        if (!in_array($ts, $holiday) && $dow != 0 && $dow != 6) break;
        $start->modify('+1 day');
    }
    while (true);
    return $start->format('d-m-Y');
}

Демонстрация на 3v4l.org

...