dqhr76378 2017-01-04 11:11
浏览 425
已采纳

计算两个日期之间的工作日

I want to calculate the number of working days.

By using carbon I can calculate days and reduce weekends.

$num_days = $to_date->diffInWeekdays($from_date) + 1;

And I have an array of holidays, and I want to reduce the number of days if there is a holiday in between the days.

Is there any way to do this.

Thank you

  • 写回答

4条回答 默认 最新

  • duanqianhuan3994 2017-01-04 11:33
    关注

    You could use diffInDaysFiltered to achieve what you're after.

    Assuming your holidays are an array of Carbon instances you could do something like:

    $start = Carbon::now()->setDate(2014, 1, 1);
    $end = Carbon::now()->setDate(2015, 1, 1);
    
    $holidays = [
        Carbon::create(2014, 2, 2),
        Carbon::create(2014, 4, 17),
        Carbon::create(2014, 5, 19),
        Carbon::create(2014, 7, 3),
    ];
    
    $days = $start->diffInDaysFiltered(function (Carbon $date) use ($holidays) {
    
        return $date->isWeekday() && !in_array($date, $holidays);
    
    }, $end);
    

    If it's just an array of strings then you could do something like:

    !in_array($date->format('[the-format-of-your-dates]'), $holidays)
    

    Hope this helps!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改