Fonction array_uintersect_assoc
La fonction array_uintersect_assoc retourne un tableau contenant tous les éléments du premier tableau qui sont présents dans tous les autres tableaux. La comparaison des clés et des valeurs est effectuée à l'aide d'une fonction de rappel utilisateur.
Syntaxe
array_uintersect_assoc(array $array1, array $array2, ..., callable $value_compare_func): array
Exemple
Comparaison de tableaux avec une fonction personnalisée :
<?php
function compare($a, $b) {
if ($a === $b) {
return 0;
}
return ($a > $b) ? 1 : -1;
}
$array1 = ["a" => "green", "b" => "brown", "c" => "blue"];
$array2 = ["a" => "GREEN", "B" => "brown", "c" => "blue"];
print_r(array_uintersect_assoc($array1, $array2, "strcasecmp"));
?>
Résultat de l'exécution du code :
Array
(
[a] => green
[c] => blue
)
Exemple
Comparaison avec des valeurs numériques :
<?php
function numCompare($a, $b) {
return $a <=> $b;
}
$array1 = [10 => "apple", 20 => "banana", 30 => "cherry"];
$array2 = [10 => 10, 20 => "banana", 40 => "cherry"];
print_r(array_uintersect_assoc($array1, $array2, "numCompare"));
?>
Résultat de l'exécution du code :
Array
(
[20] => banana
)
Voir aussi
-
la fonction
array_intersect_assoc,
qui calcule l'intersection de tableaux avec vérification des index -
la fonction
array_uintersect,
qui calcule l'intersection de tableaux avec une fonction de rappel (sans vérification des index)