溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP多字段排序數(shù)組代碼實(shí)現(xiàn)

發(fā)布時(shí)間:2020-05-11 15:37:49 來源:億速云 閱讀:229 作者:Leah 欄目:編程語言

這篇文章為大家?guī)碛嘘P(guān)PHP多字段排序數(shù)組代碼實(shí)現(xiàn)的詳細(xì)介紹。大部分知識點(diǎn)都是大家經(jīng)常用到的,為此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。

題目:

一個(gè)二維數(shù)組,需要按照庫存量排序,然后再按照門店距離排序。

發(fā)現(xiàn)了這樣一個(gè)這樣子的方法:


$array1 = array(
      0=>array('id'=>8,'name'=>'Apple','age'=> 18),
      1=>array('id'=>8,'name'=>'Bed','age'=>17),
      2=>array('id'=>5,'name'=>'Cos','age'=>16),
      3=>array('id'=>5,'name'=>'Cos','age'=>14)
);
function sortArrByManyField(){
  $args = func_get_args(); // 獲取函數(shù)的參數(shù)的數(shù)組
  if(empty($args)){
    return null;
  }
  $arr = array_shift($args);
  if(!is_array($arr)){
    throw new Exception("第一個(gè)參數(shù)不為數(shù)組");
  }
  foreach($args as $key => $field){
    if(is_string($field)){
      $temp = array();
      foreach($arr as $index=> $val){
        $temp[$index] = $val[$field];
      }
      $args[$key] = $temp;
    }
  }
  $args[] = &$arr;//引用值
  call_user_func_array('array_multisort',$args);
  return array_pop($args);
}
$arr = sortArrByManyField($array1,'id',SORT_ASC,'name',SORT_ASC,'age',SORT_DESC);
print_r($arr);

結(jié)果如下:


 array(4) {
     [0]=>array(3) {
           ["id"]=>int(5)
           ["name"]=>string(3) "Cos"
           ["age"]=>int(16)
         }
     [1]=>array(3) {
           ["id"]=>int(5)
           ["name"]=>string(3) "Cos"
           ["age"]=>int(14)
         }
     [2]=>array(3) {
           ["id"]=>int(8)
           ["name"]=>string(5) "Apple"
           ["age"]=>int(18)
         }
     [3]=>array(3) {
           ["id"]=>int(8)
           ["name"]=>string(3) "Bed"
           ["age"]=>int(17)
     }
   }

上述就是PHP多字段排序數(shù)組的詳細(xì)內(nèi)容,詳細(xì)使用情況還需要大家自己動(dòng)手實(shí)驗(yàn)使用過才能領(lǐng)會。如果想了解更多,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI