php 多维数组的排序实现代码
本文章给大家整一个php 多维数组的排序实现代码,我们在实际编码中将会用到PHP函数array_multisort()来实现这一复杂的排序,有需要了解的朋友可参考.
如数组,代码如下:
Array ( [0] => Array ( [id] => 1146 [orderid] => 3 ) [1] => Array ( [id] => 1149 [orderid] => 2 ) [2] => Array ( [id] => 170 [orderid] => 4 ) [3] => Array ( [id] => 1121 [orderid] => 3 ) [4] => Array ( [id] => 1120 [orderid] => 7 ) )
这么一个数据,想按orderid来排序,找不到内置的php函数,网上搜索了下,发现如下方法,代码如下:
$asc_func = create_function('$a,$b','
$k = "orderid";
if($a[$k] == $b[$k]) return 0;
return $a[$k]>$b[$k]?1:-1;
');
usort($arrs,$asc_func);$arrs是原数组,$k="orderid"是要排序的字段,后来对上面代码进行了升级,代码如下:
function sysSortArray($ArrayData,$KeyName1,$SortOrder1 = "SORT_ASC",$SortType1 = "SORT_REGULAR")
{
if(!is_array($ArrayData))
{
return $ArrayData;
}
// Get args number.
$ArgCount = func_num_args();
// Get keys to sort by and put them to SortRule array.
for($I = 1;$I < $ArgCount;$I ++)
{
$Arg = func_get_arg($I);
if(!eregi("SORT",$Arg))
{
$KeyNameList[] = $Arg;
$SortRule[] = '$'.$Arg;
}
else
{
$SortRule[] = $Arg;
}
}
// Get the values according to the keys and put them to array.
foreach($ArrayData AS $Key => $Info)
{
foreach($KeyNameList AS $KeyName)
{
${$KeyName}[$Key] = $Info[$KeyName];
}
}
// Create the eval string and eval it.
$EvalString = 'array_multisort('.join(",",$SortRule).',$ArrayData);';
eval ($EvalString);
return $ArrayData;
}
永久地址:http://www.phprm.com/shuzu/fs3992.html
转载随意~请带上教程地址吧^^