【问题标题】:Only working days and remove weekend and holidays in PHP只有工作日并在 PHP 中删除周末和节假日
【发布时间】:2023-03-12 15:33:01
【问题描述】:

我正在尝试仅格式化工作日,删除周六、周日和节假日。

我在我家乡的假期的“Stackoverflow”中找到了这个函数“function day_holiday()”。

据我所知,我在下面的 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");

问题是仅在周六和周日删除。假期不会被删除。什么不见​​了?有人能帮我吗?如果您有更动态的脚本,可以在此处发布。

【问题讨论】:

  • 所以,你说04-03-2019 是一个假期,但我没有看到它在你的数组中定义?话虽如此,看来您的问题可能是因为一旦发现是假期,您就没有break foreach 循环,因此循环继续,覆盖$newDate
  • @Jon Stirling 它以数组的形式出现,我正在尝试删除假期和周末。看起来它没有这样做,我正在寻求帮助,甚至比这个更好的脚本。
  • 我已经用我认为的问题更新了之前的评论。如果您正在寻找替代脚本,那么 SO 不是这个地方 :)
  • @JonStirling 我可以尝试使用脚本,但是我不知道我哪里错了,如果你能帮助我,非常感谢你
  • 我已经告诉过你,当你找到一个匹配的假期日期时,你需要一个break

标签: php arrays date days


【解决方案1】:

这可能是一种更稳健的方式来做你想做的事。该函数从开始时间创建一个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');
}

Demo on 3v4l.org

【讨论】:

  • 这个脚本很完美,我会在我的项目中使用它。我很感激有你这样的人,谢谢。和平:-)
猜你喜欢
  • 1970-01-01
  • 2015-12-29
  • 2021-10-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-08-26
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多