这个帖子 https://stackoverflow.com/questions/11012891/how-to-get-most-recent-date-from-an-array-of-dates几乎为我回答了这个问题,但我有一个特定的需求,但没有找到我想要的东西。这完全超出了我的经验;我无法完全理解它,所以我真正需要的是一个正确的方向。
假设我有一个数组,如下所示:
array(5) {
[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"
}
我希望有一种方法来提供日期(例如“2013-02-04 14:11:16”),并让一个函数确定数组中与此最接近的匹配项(这将是“2013-02 -05 16:25:07”在这种情况下)。
我将不胜感激任何提示。谢谢! :)
我可能没有最好的命名约定,但这里是。
我计算日期数组和给定日期之间的间隔。然后我进行排序,找到“最小”差异。
$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");
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)