我有一个很长的多维数组,包括一些DateTime对象。我想基于[startdate]对象对整个数组进行排序。我正在使用这个usort功能(基于许多在线资源和各种错误的修改)。它没有对数组进行排序。
我的数组格式如下。仅显示简洁的开始。
Array
(
[] => Array
(
[startdate] => DateTime Object
(
[date] => 2019-04-10 19:00:00.000000
[timezone_type] => 3
[timezone] => America/New_York
)
[starttime] => DateTime Object
(
[date] => 2019-04-10 19:00:00.000000
[timezone_type] => 3
[timezone] => America/New_York
)
这是我的代码:
function date_compare($a, $b) {
$t1 = $a["startdate"]->format('Y-m-d H:i:s');
$t2 = $b["startdate"]->format('Y-m-d H:i:s');
return $t1 - $t2;
}
usort($allEventsSimple, 'date_compare');
我还尝试使用以下代码对DateTime对象进行排序:
function date_compare($a, $b) {
$t1 = var_dump($a[startdate]);
$t2 = var_dump($b[startdate]);
return $t1 - $t2;
}
usort($allEventsSimple, 'date_compare');
你确实有错误,你只是看不到它们(见How to get useful error messages in PHP?)
你的代码会产生
PHP注意:在...中遇到一个非常好的数值
这是因为您试图从另一个中减去一个非数字字符串。
如果您使用的是PHP 7,则可以直接将DateTime
实例与名称为"spaceship operator"的实例进行比较,例如:
return $a['startdate'] <=> $b['startdate'];
如果您坚持使用PHP 5,请比较时间戳
return $a['startdate']->getTimestamp() - $b['startdate']->getTimestamp();