Funktion array_uintersect_assoc
Die Funktion array_uintersect_assoc gibt ein Array zurück, das alle Elemente des ersten Arrays enthält, die in allen anderen Arrays vorhanden sind. Der Vergleich von Schlüsseln und Werten wird mit einer benutzerdefinierten Callback-Funktion durchgeführt.
Syntax
array_uintersect_assoc(array $array1, array $array2, ..., callable $value_compare_func): array
Beispiel
Vergleich von Arrays mit einer benutzerdefinierten Funktion:
<?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"));
?>
Ergebnis der Codeausführung:
Array
(
[a] => green
[c] => blue
)
Beispiel
Vergleich mit numerischen Werten:
<?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"));
?>
Ergebnis der Codeausführung:
Array
(
[20] => banana
)
Siehe auch
-
die Funktion
array_intersect_assoc,
die die Schnittmenge von Arrays mit Indexprüfung berechnet -
die Funktion
array_uintersect,
die die Schnittmenge von Arrays mit einer Callback-Funktion berechnet (ohne Indexprüfung)