How to get closest date compared to an array of dates in PHP

前端 未结 4 1222
爱一瞬间的悲伤
爱一瞬间的悲伤 2020-11-29 06:08

This post almost answered this question for me, but I have a specific need and didn\'t find what I sought there. This lies right outside my experience; couldn\'t quite wrap

4条回答
  •  一向
    一向 (楼主)
    2020-11-29 06:29

    I may not have the best naming conventions, but here goes.

    I calculate the intervals between the array of dates and the given date. I then do a sort, to find the "smallest" difference.

    $dates = array
    (
        '0'=> "2013-02-18 05:14:54",
        '1'=> "2013-02-12 01:44:03",
        '2'=> "2013-02-05 16:25:07",
        '3'=> "2013-01-29 02:00:15",
        '4'=> "2013-01-27 18:33:45"
    );
    
    
    function find_closest($array, $date)
    {
        //$count = 0;
        foreach($array as $day)
        {
            //$interval[$count] = abs(strtotime($date) - strtotime($day));
            $interval[] = abs(strtotime($date) - strtotime($day));
            //$count++;
        }
    
        asort($interval);
        $closest = key($interval);
    
        echo $array[$closest];
    }
    
    find_closest($dates, "2013-02-18 05:14:55");
    

提交回复
热议问题