Muh*_*ees 2 php php-carbon laravel-5.3
我想计算工作日数。
通过使用碳,我可以计算天数并减少周末。
$num_days = $to_date->diffInWeekdays($from_date) + 1;
Run Code Online (Sandbox Code Playgroud)
而且我有一系列假期,如果两天之间有假期,我想减少天数。
有什么办法可以做到这一点。
谢谢
你可以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)
希望这可以帮助!
这是一个小的工作函数,用于计算工作日:
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)
您可以传递开始日期和结束日期以获取天数。
| 归档时间: |
|
| 查看次数: |
4105 次 |
| 最近记录: |