我有2名员工在星期一工作两个时间段。我希望为我们的客户提供一种简单的方法来创建按当天(晚上,下午,上午)细分的约会。
- Morning: 0001 to 1200
- Afternoon: 1201 to 1600
- Evening: 1601 to 2400
周一至周五的时间表
约翰工作:早上7点到下午1点
迈克尔工作:下午1点到晚上7点
星期六的时间表
约翰的作品:上午8点到下午12点
周一至周五应该显示按钮:上午,下午和晚上。 星期六应该只显示上午按钮。
我不确定如何实现这一点,因为约翰的日程安排在下午结束。所以我正在弄清楚如何检查时间范围是否在另一个时间范围内并返回一个bool或其他东西。
我试图将所有内容分解为开始和结束时间块,这是我成功完成的。然而,当它们将它们与一天中的时间(傍晚,下午,早晨)进行比较时,我不知道如何比较它们。
我不想试图让你们编写我的代码,我需要逻辑方面的帮助。正如你从屏幕截图中看到的那样,除了这个小而重要的部分之外,已经全部写完了。 任何想法将不胜感激!
[溶液]
我正在使用Laravel php框架的ORM,名为Eloquent。 < 3 *注意:做范围(1201,1600,5)混乱和范围(1200,1600)会导致巨大的内存消耗,所以我增加了5。
$day_segments = array(
"morning" => range(0, 1200, 5),
"afternoon" => range(1200, 1600, 5),
"evening" => range(1600, 2400, 5)
);
// On what days of the week are users working and in what time ranges?
$user_timeranges = array();
foreach ($record->users()->get() as $user) {
foreach ($user->timeblocks as $timeblock) {
$start_range = date('Hi', strtotime("{$timeblock->start_hour} {$timeblock->start_divide}"));
$end_range = date('Hi', strtotime("{$timeblock->end_hour} {$timeblock->end_divide}"));
$user_timeranges[$timeblock->day][] = range($start_range, $end_range, 5);
}
}
// On each day what day segments are available to create appointments?
$available_segments = array();
foreach ($days_available as $day) {
$available_segments[$day] = array();
foreach ($day_segments as $name => $segment) {
$available_segments[$day][$name] = 0;
foreach ($user_timeranges[$day] as $timerange) {
if (array_intersect($segment, $timerange)) {
$available_segments[$day][$name]++;
}
}
}
}
vardump($available_segments);
exit;
答案 0 :(得分:2)
由于您似乎只需要整整几个小时,因此您可以使用range()
函数定义每个细分,并为每个工作人员进行相似的操作。然后使用array_intersect
,看看你是否得到了一个结果。
示例:
$times = Array("morning"=>range(0,12),"afternoon"=>range(12,16),"evening"=>range(16,24));
$people = Array("John"=>range(7,13),"Michael"=>range(13,19));
$available = Array();
foreach($times as $k=>$v) {
$available[$k] = 0;
foreach($people as $name=>$times) {
if( array_intersect($v,$times)) $available[$k]++;
}
}
var_dump($available);