2

我有 2 名员工在星期一的两个时间段工作。我想为我们的客户提供一种简单的方法来创建按一天中的各个部分(晚上、下午、早上)细分的约会。

- Morning: 0001 to 1200
- Afternoon: 1201 to 1600
- Evening: 1601 to 2400

周一至周五的时间表
约翰工作:早上 7 点到下午 1 点
迈克尔工作:下午 1 点到晚上 7 点

周六的时间表
约翰工作:上午 8 点至下午 12 点

Mon - Fri 应该显示以下按钮:Morning、Afternoon 和 Evening。星期六应该只显示早上按钮。

我不确定如何做到这一点,因为约翰的日程安排在下午结束。所以我正在弄清楚如何检查一个时间范围是否在另一个时间范围内并返回一个布尔值或其他东西。

http://screencloud.net/img/screenshots/123e673cdad3ea47337d512f6ef2fddc.png
我试图将所有内容分解为开始和结束时间块,我成功地做到了。然而,当需要将它们与一天中的时间(晚上、下午、早上)进行比较时,我不知道如何比较它们。

我不想让你们写我的代码,我需要逻辑方面的帮助。正如您从屏幕截图中看到的那样,除了这个小而大的部分之外,这已经全部写好了。任何想法将不胜感激!

[解决方案]

我正在使用 Laravel php 框架的 ORM,称为 Eloquent。<3 * 注意:做 range(1201, 1600, 5) 搞砸了, range(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;
4

1 回答 1

2

由于您似乎只需要整整一个小时,您可以使用该range()函数定义每个段,对于每个工作人员也是如此。然后使用array_intersect,看看你是否得到一个 thruthy 的结果。

例子:

$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);
于 2012-12-17T16:44:22.590 回答