鍍金池/ 問(wèn)答/人工智能  PHP/ PHP數(shù)組排序問(wèn)題

PHP數(shù)組排序問(wèn)題

    $array = [
              ['num'=>22,'time'=>'2017-10-23','name'=>'小王'],
              ['num'=>22,'time'=>'2017-10-21','name'=>'小白'],
              ['num'=>123,'time'=>'2017-09-23','name'=>'小李'],
              ['num'=>456,'time'=>'2017-10-23','name'=>'小黑'],
              ['num'=>123,'time'=>'2017-09-28','name'=>'小豬'],
              ['num'=>298,'time'=>'2017-10-23','name'=>'小狗']
            ];

按下標(biāo)num倒序排列, num一樣的按time升序。。 各位老哥。有什么好的辦法或者思路嗎?

回答
編輯回答
未命名

你需要好好看看這個(gè)函數(shù)的作用了 array_multisort

<?php
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);

//本例中將把 volume 降序排列,把 edition 升序排列。

//現(xiàn)在有了包含有行的數(shù)組,但是 array_multisort() 需要一個(gè)包含列的數(shù)組,因此用以下代碼來(lái)取得列,然后排序。


// 取得列的列表
foreach ($data as $key => $row) {
    $volume[$key]  = $row['volume'];
    $edition[$key] = $row['edition'];
}

// 將數(shù)據(jù)根據(jù) volume 降序排列,根據(jù) edition 升序排列
// 把 $data 作為最后一個(gè)參數(shù),以通用鍵排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
?>

傳送門:
http://tw1.php.net/manual/en/...

2018年2月18日 14:57
編輯回答
擱淺

可以使用array_multisort()函數(shù),上代碼:

$array = [
    ['num'=>22,'time'=>'2017-10-23','name'=>'小王'],
    ['num'=>22,'time'=>'2017-10-21','name'=>'小白'],
    ['num'=>123,'time'=>'2017-09-23','name'=>'小李'],
    ['num'=>456,'time'=>'2017-10-23','name'=>'小黑'],
    ['num'=>123,'time'=>'2017-09-28','name'=>'小豬'],
    ['num'=>298,'time'=>'2017-10-23','name'=>'小狗']
];

$columns = array_keys($array[0]);

$arrToSort = $resArr = [];
foreach($array as $v) {
    foreach($columns as $k => $key) {
        $arrToSort[$k][] = $v[$key];
    }
}

array_multisort($arrToSort[0], SORT_DESC, SORT_NUMERIC, $arrToSort[1], SORT_ASC, SORT_STRING, $arrToSort[2]);

foreach($arrToSort as $k => $v) {
    foreach($v as $v_k => $v_v) {
        $resArr[$v_k][$columns[$k]] = $v_v;
    }
}

echo json_encode($resArr);

得到結(jié)果:
圖片描述

其中注意一下array_multisort()函數(shù)在其中起到的關(guān)鍵作用:
圖片描述

2018年8月13日 00:18
編輯回答
喜歡你

核心代碼就大概是這個(gè)樣子了,沒(méi)有考慮時(shí)間是字符串的問(wèn)題,你將就看一下改一改吧


 $array = [
              ['num'=>22,'time'=>'2017-10-23','name'=>'小王'],
              ['num'=>22,'time'=>'2017-10-21','name'=>'小白'],
              ['num'=>123,'time'=>'2017-09-23','name'=>'小李'],
              ['num'=>456,'time'=>'2017-10-23','name'=>'小黑'],
              ['num'=>123,'time'=>'2017-09-28','name'=>'小豬'],
              ['num'=>298,'time'=>'2017-10-23','name'=>'小狗']
            ];


function cmp($a, $b)
{
    if ($a['num'] == $b['num']) {
        return $a['time']<$b['time'] ? -1 : 1;
    }
    return ($a['num'] > $b['num']) ? -1 : 1;
}

usort($array, "cmp");

var_dump ($array);
2017年3月23日 19:57