recherche

Maison  >  Questions et réponses  >  le corps du texte

Comment déterminer si les tableaux multidimensionnels non ordonnés sont les mêmes en PHP ?

L'exemple est le suivant :
L'opération réelle est un tableau tridimensionnel et la quantité de données est relativement importante.


    $une = [
        ['name'=>'jack', 'gender'=>'male'],
        ['age'=>18,'country'=>'Chine']
    ];
    $b = [
        ['pays'=>'Chine','age'=>18],
        ['genre'=>'male','name'=>'jack']
    ];

En plus de parcourir et de comparer, existe-t-il un moyen rapide et efficace ?
Mon idée actuelle est de trier d'abord le tableau selon les mêmes règles, puis d'utiliser la vérification md5 après json_encoding. Cependant, il semble que le tri ne puisse pas être correctement mis en œuvre à l’heure actuelle.
Je me demande si vous avez de bonnes méthodes ?

PHPzPHPz2773 Il y a quelques jours493

répondre à tous(4)je répondrai

  • 大家讲道理

    大家讲道理2017-05-16 13:14:54

    //Applicable uniquement aux tableaux purement associatifs
    function deep_ksort(&$arr) {

    ksort($arr); 
    foreach ($arr as &$a) { 
        if (is_array($a) && !empty($a)) { 
            deep_ksort($a); 
        } 
    } 

    }
    deep_ksort($a);
    deep_ksort($b);
    if(json_encode($a) == json_encode($b)){

        echo "两个数组相同";

    }


    //Méthode générale
    //Cette fonction convertit un tableau multidimensionnel en un tableau unidimensionnel
    fonction multiToSingle($arr, $delimiter = '->',$key = ' ') {

    $resultAry = array();
    if (!(is_array($arr) && count($arr)>0)) {
        return false;
    }
    foreach ($arr AS $k=>$val) {
        $k = is_numeric($k) ? 0 :$k;    //若键是数字,则统一为0,避免索引不同导致数组的不同
        $newKey = trim($key . $k . $delimiter);
        if (is_array($val) && count($val)>0) {
            $resultAry = array_merge($resultAry, multiToSingle($val, $delimiter, $newKey));
        } else {
            $resultAry[] = $newKey . $val;
        }
    }
    return $resultAry;

    }
    //Juge si deux tableaux sont congrus
    fonction juge($a,$b)
    {

    $single_A = multiToSingle($a);
    $single_B = multiToSingle($b);
    $arr1 = array_diff($single_A,$single_B);
    $arr2 = array_diff($single_B,$single_A);

    if(vide($arr1) && vide($arr2)){

       echo "两数组全等";

    }autre{

       echo "不全等";

    };

    }

    répondre
    0
  • 迷茫

    迷茫2017-05-16 13:14:54

    Vous pouvez jeter un œil à ce http://bbs.csdn.net/topics/36..., cela devrait vous être utile !

    répondre
    0
  • 天蓬老师

    天蓬老师2017-05-16 13:14:54

    C'est très simple. Après avoir trié selon les mêmes règles, convertissez le tableau en chaîne et comparez si les deux chaînes sont identiques

    répondre
    0
  • PHP中文网

    PHP中文网2017-05-16 13:14:54

    
    $a = [
        ['name' => 'jack', 'gender' => 'male'],
        ['age' => 18, 'country' => 'China']
    ];
    $b = [
        ['country' => 'China', 'age' => 18],
        ['gender' => 'male', 'name' => 'jack']
    ];
    
    
    function whetherDifferent($ele, $differentEle)
    {
        $toSingleArr = function ($target)use(&$toSingleArr){
                //转换为一维数组的代码
            return $target;
        };
        $ele=$toSingleArr($ele);
        $differentEle=$toSingleArr($differentEle);
        ksort($ele,true);
        ksort($differentEle,true);
        return $ele===$differentEle;
    }
    
    
    var_dump(whetherDifferent($a, $b));
    die;
    

    répondre
    0
  • Annulerrépondre