PHP 對二維數組排序

來源:互聯網
上載者:User
現在有一個二維數組

$arr = array(    array('date'=>'2011-04-21','wu'=>'test'),    array('date'=>'2014-04-21','wu'=>'good'),    array('date'=>'2011-12-22','wu'=>'great'),    array('date'=>'2012-05-21','wu'=>'hahah'),    array('date'=>'2013-08-13','wu'=>'test'),    array('date'=>'2011-04-25','wu'=>'yes'),    array('date'=>'2014-04-14','wu'=>'no'),);

我想將它按照裡面date日期來重新排序,得到這樣的新數組:

$arr2 = array(    array('date'=>'2011-04-21','wu'=>'test'),    array('date'=>'2011-04-25','wu'=>'yes'),    array('date'=>'2011-12-22','wu'=>'great'),    array('date'=>'2012-05-21','wu'=>'hahah'),    array('date'=>'2013-08-13','wu'=>'test'),    array('date'=>'2014-04-14','wu'=>'no'),    array('date'=>'2014-04-21','wu'=>'good'),);

請問應該怎樣做呢?

回複內容:

現在有一個二維數組

$arr = array(    array('date'=>'2011-04-21','wu'=>'test'),    array('date'=>'2014-04-21','wu'=>'good'),    array('date'=>'2011-12-22','wu'=>'great'),    array('date'=>'2012-05-21','wu'=>'hahah'),    array('date'=>'2013-08-13','wu'=>'test'),    array('date'=>'2011-04-25','wu'=>'yes'),    array('date'=>'2014-04-14','wu'=>'no'),);

我想將它按照裡面date日期來重新排序,得到這樣的新數組:

$arr2 = array(    array('date'=>'2011-04-21','wu'=>'test'),    array('date'=>'2011-04-25','wu'=>'yes'),    array('date'=>'2011-12-22','wu'=>'great'),    array('date'=>'2012-05-21','wu'=>'hahah'),    array('date'=>'2013-08-13','wu'=>'test'),    array('date'=>'2014-04-14','wu'=>'no'),    array('date'=>'2014-04-21','wu'=>'good'),);

請問應該怎樣做呢?

直接上代碼

$tmp = array();foreach ($arr as $a) {    $tmp[$a['date'] . '_' . $a['wu'] . '_' . rand(1000000, 9999999)] = $a;}asort($tmp);$arr = array_values($tmp);

使用 array_multisort
參考:http://cn2.php.net/array_multisort

php$sort = array(      'direction' => 'SORT_ASC', //排序次序標誌 SORT_DESC 降序;SORT_ASC 升序      'field'     => 'date',       //排序欄位  );$arrSortTmp = array();  foreach($arr AS $uniqid => $row){      foreach($row AS $key=>$value){          $arrSortTmp[$key][$uniqid] = $value;      }  }array_multisort($arrSortTmp[$sort["field"]],constant($sort["direction"]), $arr);var_dump($arr);

$arr = array(
array('date'=>'2011-04-21','wu'=>'test'),
array('date'=>'2014-04-21','wu'=>'good'),
array('date'=>'2011-12-22','wu'=>'great'),
array('date'=>'2012-05-21','wu'=>'hahah'),
array('date'=>'2013-08-13','wu'=>'test'),
array('date'=>'2011-04-25','wu'=>'yes'),
array('date'=>'2014-04-14','wu'=>'no'),
);

array_multisort($arr, SORT_ASC);

print_r($arr);

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.