Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/279.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/arrays/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
基于索引的php数组的自定义顺序_Php_Arrays_Sorting - Fatal编程技术网

基于索引的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

我有一个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 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])
会更好,但这取决于这个函数应该如何准确地运行…