我有一个Multilevel Array
(请参阅下面的数组结构图),我需要获得更高date value
的子嵌套数组。
我想知道是否有一种直接的方法可以按date value
对子嵌套数组进行排序,或者获得最高date value
?
阵列地图
答案 0 :(得分:2)
为此,usort()功能将非常有用:
usort($rgData, function($rgX, $rgY)
{
$x = strtotime($rgX['date']);
$y = strtotime($rgY['date']);
return $x<$y?-1:$x!=$y;
});
//var_dump($rgData);
如果您想获得最高价值,那么在进行上述排序后,它将是最后一个元素的['date']
键。
编辑:如果您确定该格式与图片上的格式完全相同,您可以通过strcmp
使用直接字符串比较(这可能会更快)
答案 1 :(得分:1)
如何使用usort()
:
$input = array(
array('date' => '2013-09-11 13:08:40 +0000'),
array('date' => '2013-09-11 13:09:17 +0000'));
usort($input, function(array $a, array $b) {
$aTimestamp = strtotime($a['date']);
$bTimestamp = strtotime($b['date']);
if($aTimestamp == $bTimestamp) return 0;
return $aTimestamp < $bTimestamp;
});
print_r($input); //$input[0] has the latest date value