>백엔드 개발 >PHP 튜토리얼 >PHP 对二维数组排序

PHP 对二维数组排序

WBOY
WBOY원래의
2016-06-06 20:32:181150검색

现在有一个二维数组

<code>$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'),
);
</code>

我想将它按照里面date日期来重新排序,得到这样的新数组:

<code>$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'),
);
</code>

请问应该怎样做呢?

回复内容:

现在有一个二维数组

<code>$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'),
);
</code>

我想将它按照里面date日期来重新排序,得到这样的新数组:

<code>$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'),
);
</code>

请问应该怎样做呢?

直接上代码

<code>$tmp = array();

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

asort($tmp);

$arr = array_values($tmp);
</code>

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

<code>php</code><code>$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);
</code>

$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);

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.