array_uintersect_assoc

(PHP 5, PHP 7, PHP 8)

array_uintersect_assocCalcula la intersección de dos arrays con pruebas sobre el índice, compara los datos utilizando una función de retrollamada

Descripción

array_uintersect_assoc(array $array, array ...$arrays, callable $value_compare_func): array

Calcula la intersección de dos arrays con pruebas sobre el índice, compara los datos utilizando una función de retrollamada.

Téngase en cuenta que las claves se utilizan en la comparación en contraste con la función array_uintersect(). Los datos se comparan utilizando una función de retrollamada.

Parámetros

array

El primer array.

arrays

Arrays a comparar contra

value_compare_func

La función de comparación debe retornar un entero menor que, igual a, o mayor que 0 si el primer argumento es considerado, respectivamente, menor que, igual a, o mayor que el segundo.

callback(mixed $a, mixed $b): int
Precaución

Retornar valores no-entero desde la función de comparación, tales como float, resultará en una conversión interna del valor de retorno del callback a int. Así, valores tales como 0.99 y 0.1 serán convertidos ambos a un valor entero de 0, lo que comparará tales valores como iguales.

Precaución

La función de callback de ordenación debe tratar cualquier valor de cualquier array en cualquier orden, independientemente del orden en el que fueron proporcionados inicialmente. Esto se debe a que cada array individual es ordenado primero antes de ser comparado con otros arrays. Por ejemplo :

<?php
$arrayA
= ["cadena", 1];
$arrayB = [["value" => 1]];
// $item1 y $item2 pueden ser cualquiera de los siguientes valores : "cadena", 1 o ["value" => 1]
$compareFunc = static function ($item1, $item2) {
$value1 = is_string($item1) ? strlen($item1) : (is_array($item1) ? $item1["value"] : $item1);
$value2 = is_string($item2) ? strlen($item2) : (is_array($item2) ? $item2["value"] : $item2);
return
$value1 <=> $value2;
};
?>

Valores devueltos

Devuelve un array que contiene todos los valores del array array que están presentes en todos los otros argumentos.

Ejemplos

Ejemplo #1 Ejemplo con array_uintersect_assoc()

<?php
$array1
= array("a" => "green", "b" => "brown", "c" => "blue", "red");
$array2 = array("a" => "GREEN", "B" => "brown", "yellow", "red");

print_r(array_uintersect_assoc($array1, $array2, "strcasecmp"));
?>

El ejemplo anterior mostrará :

Array
(
    [a] => green
)

Ver también

  • array_uintersect() - Calcula la intersección de dos arrays, compara los datos utilizando una función de retrollamada
  • array_intersect_assoc() - Calcula la intersección de dos arrays con pruebas sobre los índices
  • array_intersect_uassoc() - Calcula la intersección de dos arrays con pruebas en los índices, compara los índices utilizando una función de retrollamada
  • array_uintersect_uassoc() - Calcula la intersección de dos arrays con pruebas en el índice, compara los datos y los índices de los dos arrays utilizando una función de retrollamada separada

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top