首页 > 后端开发 > php教程 > PHP 对二维数组排序

PHP 对二维数组排序

WBOY
发布: 2016-06-06 20:32:18
原创
1129 人浏览过

现在有一个二维数组

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

相关标签:
php
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板