douxue4395 2014-07-17 09:54
浏览 40
已采纳

使用php中的日期排序数组数组

$data = array( 
    array("firstname" => "Mary", "age" => 25,"date" => '14/07/2014 04:50'), 
    array("firstname" => "Amanda","age" => 18 ,"date" => '14/07/2014 13:20'), 
    array("firstname" => "James", "age" => 31 ,"date" => '10/07/2014 03:00'), 
    array("firstname" => "Patricia","age" => 7 ,"date" => '09/07/2010 06:32'), 
    array("firstname" => "Michael", "age" => 43 ,"date" => '10/01/2010 04:50'), 
    array("firstname" => "Ranga","age" => 23,"date"=> '08/06/1990 03:52' ),
    array("firstname" => "Sarah","age" => 24 ,"date" => '08/06/1991 04:25'), 
    array("firstname" => "Patrick","age" => 27 ,"date" => '19/07/2002 04:50'),
);

function compare_date($a, $b) { 
    return strnatcmp($a['date'], $b['date']); 
} 

usort($data, 'compare_date');

print_r($data);

It's not working. Please help.

  • 写回答

3条回答 默认 最新

  • douchuifk90315 2014-07-17 09:59
    关注

    Compare them by as dates, not natural order

    function compare_date($a, $b) {
        return (strtotime(str_replace('/', '.', $a['date'])) < strtotime(str_replace('/', '.',   $b['date']))) ? -1 : 1;
    }
    

    14/07/2014 04:50 assumes 14 is the day and 7 is the month. But strtotime will see them the other way around. I am replacing / with . so

    14/07/2014 04:50 becomes 14.07.2014 04:50

    14.07.2014 04:50 will be interpreted properly by strtotime

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 poi合并多个word成一个新word,原word中横版没了.
  • ¥15 【火车头采集器】搜狐娱乐这种列表页网址,怎么采集?
  • ¥15 求MCSCANX 帮助
  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?