Comment déterminer si les tableaux multidimensionnels non ordonnés sont les mêmes en PHP ?
PHPz
PHPz 2017-05-16 13:12:54
0
4
523

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 ?

PHPz
PHPz

学习是最好的投资!

répondre à tous(4)
大家讲道理

//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 "不全等";

};

}

迷茫

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

Peter_Zhu

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

Ty80

$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;
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal