Funkcja array_uintersect_assoc
Funkcja array_uintersect_assoc zwraca tablicę zawierającą wszystkie elementy z pierwszej tablicy, które występują we wszystkich pozostałych tablicach. Porównywanie kluczy i wartości jest wykonywane za pomocą dostarczonej funkcji callback.
Składnia
array_uintersect_assoc(array $array1, array $array2, ..., callable $value_compare_func): array
Przykład
Porównywanie tablic z funkcją użytkownika:
<?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"));
?>
Wynik wykonania kodu:
Array
(
[a] => green
[c] => blue
)
Przykład
Porównywanie z wartościami liczbowymi:
<?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"));
?>
Wynik wykonania kodu:
Array
(
[20] => banana
)
Zobacz też
-
funkcję
array_intersect_assoc,
która oblicza przecięcie tablic ze sprawdzaniem indeksów -
funkcję
array_uintersect,
która oblicza przecięcie tablic z funkcją callback (bez sprawdzania indeksów)