按日期键按子数组对 PHP 数组排序
Order PHP array by sub-array by date key
我知道这个问题已被问过一百次,我已经回答了多个问题,但没有得到正确的结果。
我正在尝试按日期对以下行进行排序,最早的在前:
Array(
[0] => Array
(
[0] => '3173'
[1] => 'Contact - 12-6-14 Outstanding invoice'
[2] => '16/06/2014'
[3] => '204'
)
[1] => Array
(
[0] => '3167'
[1] => 'Contact - Outstanding invoice'
[2] => '13/06/2014'
[3] => '207'
)
[2] => Array
(
[0] => '3497'
[1] => 'New Site - Keri Keri'
[2] => '25/11/2014'
[3] => '43'
)
[3] => Array
(
[0] => '2023'
[1] => 'Analysis'
[2] => '17/06/2014'
[3] => '355'
)
[4] => Array
(
[0] => '2641'
[1] => 'PSS'
[2] => '20/02/2014'
[3] => '321'
)
)
我已经尝试过以下方法,但没有成功。
function cmp($a, $b){
return $b[2] - $a[2];
}
usort($urgent_array, "cmp");
如果您对此有任何帮助,我们将不胜感激:)
首先,你要比较,而不是减去:
function cmp($a, $b) {
if ($a[2] == $b[2])
return 0;
return ($a[2] > $b[2]) ? 1 : -1;
}
usort($urgent_array, "cmp");
那么,如果您使用 Y-m-d
格式,日期排序效果最佳:
2014-06-13
等
将您的比较功能更改为
function cmp($a, $b){
$a_date = strtotime(str_replace('/', '-', $a[2]));
$b_date = strtotime(str_replace('/', '-', $b[2]));
return $a_date - $b_date;
}
您想使用 strtotime,因为减去字符串实际上没有任何意义。 str_replace 是因为 PHP 需要 dd-mm-yyyy 格式的破折号。
我知道这个问题已被问过一百次,我已经回答了多个问题,但没有得到正确的结果。
我正在尝试按日期对以下行进行排序,最早的在前:
Array(
[0] => Array
(
[0] => '3173'
[1] => 'Contact - 12-6-14 Outstanding invoice'
[2] => '16/06/2014'
[3] => '204'
)
[1] => Array
(
[0] => '3167'
[1] => 'Contact - Outstanding invoice'
[2] => '13/06/2014'
[3] => '207'
)
[2] => Array
(
[0] => '3497'
[1] => 'New Site - Keri Keri'
[2] => '25/11/2014'
[3] => '43'
)
[3] => Array
(
[0] => '2023'
[1] => 'Analysis'
[2] => '17/06/2014'
[3] => '355'
)
[4] => Array
(
[0] => '2641'
[1] => 'PSS'
[2] => '20/02/2014'
[3] => '321'
)
)
我已经尝试过以下方法,但没有成功。
function cmp($a, $b){
return $b[2] - $a[2];
}
usort($urgent_array, "cmp");
如果您对此有任何帮助,我们将不胜感激:)
首先,你要比较,而不是减去:
function cmp($a, $b) {
if ($a[2] == $b[2])
return 0;
return ($a[2] > $b[2]) ? 1 : -1;
}
usort($urgent_array, "cmp");
那么,如果您使用 Y-m-d
格式,日期排序效果最佳:
2014-06-13
等
将您的比较功能更改为
function cmp($a, $b){
$a_date = strtotime(str_replace('/', '-', $a[2]));
$b_date = strtotime(str_replace('/', '-', $b[2]));
return $a_date - $b_date;
}
您想使用 strtotime,因为减去字符串实际上没有任何意义。 str_replace 是因为 PHP 需要 dd-mm-yyyy 格式的破折号。