您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

PHP 对二维数组排序

2024/3/9 4:44:11发布38次查看
现在有一个二维数组
$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);
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product