基于索引的php数组的自定义顺序
我有一个PHP数组,看起来像基于索引的php数组的自定义顺序,php,arrays,sorting,Php,Arrays,Sorting,我有一个PHP数组,看起来像 $my_arr['cats'] = array('Shadow', 'Tiger', 'Luna'); $my_arr['dogs'] = array('Buddy', 'Lucy', 'Bella'); $my_arr['dolphins'] = array('Sunny', 'Comet', 'Pumpkin'); $my_arr['lizzards'] = array('Apollo', 'Eddie', 'Bruce'); //and many more l
$my_arr['cats'] = array('Shadow', 'Tiger', 'Luna');
$my_arr['dogs'] = array('Buddy', 'Lucy', 'Bella');
$my_arr['dolphins'] = array('Sunny', 'Comet', 'Pumpkin');
$my_arr['lizzards'] = array('Apollo', 'Eddie', 'Bruce');
//and many more lines like this
我需要使用排序数组根据it键对其进行排序,如
$order = array('lizzards', 'cats');
我希望第一个项目应该是lizzards数组,第二个项目-cats然后是$order数组中未指定的所有项目。如何使用usort/uasort/uksort函数实现这一点?您可以通过以下代码实现这一点
<?php
function sortByKey(&$arr,$key_order)
{
if(count(array_intersect(array_keys($arr),$key_order))!=count($key_order))
{
return false;
}
$ordered_keys=array_merge($key_order,array_diff(array_keys($arr),$key_order));
$sorted_arr=[];
foreach($ordered_keys as $key)
{
$sorted_arr[$key]=$arr[$key];
}
$arr=$sorted_arr;
return true;
}
$my_arr=[];
$my_arr['cats'] = array('Shadow', 'Tiger', 'Luna');
$my_arr['dogs'] = array('Buddy', 'Lucy', 'Bella');
$my_arr['dolphins'] = array('Sunny', 'Comet', 'Pumpkin');
$my_arr['lizzards'] = array('Apollo', 'Eddie', 'Bruce');
$order = array('lizzards', 'cats');
if(sortByKey($my_arr,$order){
echo "Sorting done successfully";
}
else
{
echo "Sorting ignored, order element miss matched";
}
print_r($my_arr);
?>
您可以通过以下代码实现这一点
<?php
function sortByKey(&$arr,$key_order)
{
if(count(array_intersect(array_keys($arr),$key_order))!=count($key_order))
{
return false;
}
$ordered_keys=array_merge($key_order,array_diff(array_keys($arr),$key_order));
$sorted_arr=[];
foreach($ordered_keys as $key)
{
$sorted_arr[$key]=$arr[$key];
}
$arr=$sorted_arr;
return true;
}
$my_arr=[];
$my_arr['cats'] = array('Shadow', 'Tiger', 'Luna');
$my_arr['dogs'] = array('Buddy', 'Lucy', 'Bella');
$my_arr['dolphins'] = array('Sunny', 'Comet', 'Pumpkin');
$my_arr['lizzards'] = array('Apollo', 'Eddie', 'Bruce');
$order = array('lizzards', 'cats');
if(sortByKey($my_arr,$order){
echo "Sorting done successfully";
}
else
{
echo "Sorting ignored, order element miss matched";
}
print_r($my_arr);
?>
使用uksort的较短解决方案:
uksort($my_arr, function ($a,$b) use ($order) {
//Look for elements indexes in the 'order' array
$aKey = array_search($a, $order);
$bKey = array_search($b, $order);
if($aKey !== FALSE && $bKey !== FALSE) {
return $aKey - $bKey;
} else if($aKey !== FALSE) {
return -1;
} else if($bKey !== FALSE) {
return 1;
}
return 0;
});
使用uksort的较短解决方案:
uksort($my_arr, function ($a,$b) use ($order) {
//Look for elements indexes in the 'order' array
$aKey = array_search($a, $order);
$bKey = array_search($b, $order);
if($aKey !== FALSE && $bKey !== FALSE) {
return $aKey - $bKey;
} else if($aKey !== FALSE) {
return -1;
} else if($bKey !== FALSE) {
return 1;
}
return 0;
});
您根本不需要使用排序算法
如果您知道指定的元素将存在于主数组中,那么请使用前导元素的键创建一个数组,然后将主数组放置在其中的一个上
代码:()
或
您根本不需要使用排序算法
如果您知道指定的元素将存在于主数组中,那么请使用前导元素的键创建一个数组,然后将主数组放置在其中的一个上
代码:()
或
您正在寻找多数组排序?不,我不需要对内部数组进行排序。你在找多数组排序吗?不,我不需要为内部阵列排序好的;唯一需要注意的是:这要求所有订单密钥都存在于$my\u arr
中。如果不能保证这一点,则需要对此进行签入。@deceze,如果您运行此代码,则可以看到它正在对整个数组进行排序,只按顺序指定了两项array@deceze,我也做了一些改变,如果订单键不匹配,则返回false@moonvader我指出了另一个方面的问题:如果不是$order
中的所有值实际上都作为$my_arr
@Haresh中的键存在,那么在循环中使用一个简单的if(isset($arr[$key])
会更好,但这取决于这个函数应该如何准确地工作……好的一个;唯一需要注意的是:这要求所有订单密钥都存在于$my\u arr
中。如果不能保证这一点,则需要对此进行签入。@deceze,如果您运行此代码,则可以看到它正在对整个数组进行排序,只按顺序指定了两项array@deceze,我也做了一些改变,如果订单键不匹配,则返回false@moonvader我指出了另一个方面的问题:如果不是$order
中的所有值实际上都作为$my_arr
@Haresh中的键存在,那么在循环中使用一个简单的if(isset($arr[$key])
会更好,但这取决于这个函数应该如何准确地运行…