繁体   English   中英

在对象数组中查找最接近的日期/时间

[英]Find closest date/time in Array of Objects

我正在寻找有关找到最接近的startTime(推荐的startTime)的最佳方法的建议。

到目前为止,我得到的是:

<?php
$array = array(    array("meeting_id" => "1812",  
                         "startTime" => "2016-10-07 14:30:00", 
                         "endTime" => "2016-10-07 14:35:00"),
                   array("meeting_id" => "1812",  
                         "startTime" => "2016-10-07 14:35:00", 
                         "endTime" => "2016-10-07 14:40:00"),
                   array("meeting_id" => "1812",  
                         "startTime" => "2016-10-07 14:40:00", 
                         "endTime" => "2016-10-07 14:45:00"),
                   array("meeting_id" => "1813",  
                         "startTime" => "2016-10-07 15:05:00", 
                         "endTime" => "2016-10-07 15:10:00"),
                   array("meeting_id" => "1813",  
                         "startTime" => "2016-10-07 15:10:00", 
                         "endTime" => "2016-10-07 15:15:00"),
                   array("meeting_id" => "1813",  
                         "startTime" => "2016-10-07 15:20:00", 
                         "endTime" => "2016-10-07 15:25:00"),
    );

arsort($array);
$firstTime = $array[0];
foreach($array as $key){
    if($firstTime["startTime"] > $key["endTime"]){
        // Do something in here.
    }
}

print_r($array);


?>

打印数组:

Array
(
    [5] => Array
        (
            [meeting_id] => 1813
            [startTime] => 2016-10-07 15:20:00
            [endTime] => 2016-10-07 15:25:00
        )

    [4] => Array
        (
            [meeting_id] => 1813
            [startTime] => 2016-10-07 15:10:00
            [endTime] => 2016-10-07 15:15:00
        )

    [3] => Array
        (
            [meeting_id] => 1813
            [startTime] => 2016-10-07 15:05:00
            [endTime] => 2016-10-07 15:10:00
        )

    [2] => Array
        (
            [meeting_id] => 1812
            [startTime] => 2016-10-07 14:40:00
            [endTime] => 2016-10-07 14:45:00
        )

    [1] => Array
        (
            [meeting_id] => 1812
            [startTime] => 2016-10-07 14:35:00
            [endTime] => 2016-10-07 14:40:00
        )

    [0] => Array
        (
            [meeting_id] => 1812
            [startTime] => 2016-10-07 14:30:00
            [endTime] => 2016-10-07 14:35:00
        )

)

我希望它如何工作:

  • 找到meeting_id == 1812的最早开始时间,然后找到其ID!= 1812的最近的下一次会议。但是,那些会议ID!= 1812的开始时间必须大于所选的结束时间1812

以下函数将您的数组作为第一个参数,并将会议ID作为第二个参数,然后将最近的会议返回到ID不是$id的最早的会议:

function get_nearest_meeting($meetings, $id)
{
    // Start by sorting the meetings:
    function sorter($a, $b)
    {
        return strtotime($a['startTime']) - strtotime($b['startTime']);
    }
    usort($meetings, 'sorter');

    foreach( $meetings as $meeting )
    {
        if( $meeting['meeting_id'] == $id)
        {
            $earliest = strtotime( $meeting['endTime'] );
            break;
        }
    }

    // Now loop over again and get the next meeting:
    foreach( $meetings as $meeting )
    {
        if( $meeting['meeting_id'] != $id && strtotime($meeting['startTime']) > $earliest)
        {
            return $meeting;
        }
    }
}

给出以下输入(存储在$meetings ):

Array
(
    [0] => Array
        (
            [errors] => 0
            [meeting_id] => 1812
            [id] => 31305
            [startTime] => 2016-10-07 14:00:00
            [endTime] => 2016-10-07 14:10:00
            [grade_id] => 87
        )

    [1] => Array
        (
            [errors] => 0
            [meeting_id] => 1813
            [id] => 31305
            [startTime] => 2016-10-07 14:10:00
            [endTime] => 2016-10-07 14:20:00
            [grade_id] => 87
        )

    [2] => Array
        (
            [errors] => 0
            [meeting_id] => 1812
            [id] => 31305
            [startTime] => 2016-10-07 14:10:00
            [endTime] => 2016-10-07 14:20:00
            [grade_id] => 87
        )

    [3] => Array
        (
            [errors] => 0
            [meeting_id] => 1812
            [id] => 31305
            [startTime] => 2016-10-07 14:20:00
            [endTime] => 2016-10-07 14:30:00
            [grade_id] => 87
        )

    [4] => Array
        (
            [errors] => 0
            [meeting_id] => 1813
            [id] => 31305
            [startTime] => 2016-10-07 14:20:00
            [endTime] => 2016-10-07 14:30:00
            [grade_id] => 87
        )

    [5] => Array
        (
            [errors] => 0
            [meeting_id] => 1815
            [id] => 31305
            [startTime] => 2016-10-07 14:30:00
            [endTime] => 2016-10-07 14:40:00
            [grade_id] => 87
        )

    [6] => Array
        (
            [errors] => 0
            [meeting_id] => 1812
            [id] => 31305
            [startTime] => 2016-10-07 14:30:00
            [endTime] => 2016-10-07 14:40:00
            [grade_id] => 87
        )

    [7] => Array
        (
            [errors] => 0
            [meeting_id] => 1813
            [id] => 31305
            [startTime] => 2016-10-07 14:30:00
            [endTime] => 2016-10-07 14:40:00
            [grade_id] => 87
        )

    [8] => Array
        (
            [errors] => 0
            [meeting_id] => 1815
            [id] => 31305
            [startTime] => 2016-10-07 14:40:00
            [endTime] => 2016-10-07 14:50:00
            [grade_id] => 87
        )

    [9] => Array
        (
            [errors] => 0
            [meeting_id] => 1813
            [id] => 31305
            [startTime] => 2016-10-07 14:40:00
            [endTime] => 2016-10-07 14:50:00
            [grade_id] => 87
        )

)

并这样称呼它:

get_nearest_meeting($meetings, 1812);

我们最终得到以下结果:

Array
(
    [errors] => 0
    [meeting_id] => 1813
    [id] => 31305
    [startTime] => 2016-10-07 14:10:00
    [endTime] => 2016-10-07 14:20:00
    [grade_id] => 87
)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM