计算日期之间的工作日

Muh*_*ees 2 php php-carbon laravel-5.3

我想计算工作日数。

通过使用碳,我可以计算天数并减少周末。

$num_days = $to_date->diffInWeekdays($from_date) + 1;
Run Code Online (Sandbox Code Playgroud)

而且我有一系列假期,如果两天之间有假期,我想减少天数。

有什么办法可以做到这一点。

谢谢

Rwd*_*Rwd 7

你可以diffInDaysFiltered用来实现你所追求的。

假设您的假期是一系列Carbon实例,您可以执行以下操作:

$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);
Run Code Online (Sandbox Code Playgroud)

如果它只是一个字符串数组,那么您可以执行以下操作:

!in_array($date->format('[the-format-of-your-dates]'), $holidays)
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助!


Tha*_*lan 5

这是一个小的工作函数,用于计算工作日:

function getWorkingDaysCount($from, $to) {
    $workingDays = [1, 2, 3, 4, 5];         // Working days (week days)
    $holidayDays = ['*-12-25', '*-01-01'];  // Holidays array, add desired dates to this array 

    $from = new DateTime($from);
    $to = new DateTime($to);
    $to->modify('+1 day');
    $interval = new DateInterval('P1D');
    $periods = new DatePeriod($from, $interval, $to);

    $days = 0;
    foreach ($periods as $period) {
      if (!in_array($period->format('N'), $workingDays)) continue;
      if (in_array($period->format('Y-m-d'), $holidayDays)) continue;
      if (in_array($period->format('*-m-d'), $holidayDays)) continue;
      $days++;
  }
  return $days;
}
Run Code Online (Sandbox Code Playgroud)

您可以传递开始日期和结束日期以获取天数。