[英]Find the most recent date from a nested array
我有一個Multilevel Array
( 請參見下面的數組結構圖 ),我需要獲取具有較高date value
的子嵌套數組。
我想知道是否有一種直接的方法可以按date value
對子嵌套數組進行排序或獲得最高的date value
?
陣列圖
為此, 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
使用直接字符串比較(這可能會更快)
如何使用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
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.