(PHP 5 >= 5.1.0, PHP 7, PHP 8)
array_intersect_key — Calcula a interseção de arrays, comparando pelas chaves
array_intersect_key() retorna um array contendo todos os valores de array
que tem as mesmas chaves presentes em todos os argumentos.
array
O array com as chaves a serem verificadas.
arrays
Arrays para comparar as chaves.
Retorna um array associativo contendo todos os valores de array
que estão presentes em todos os argumentos.
Versão | Descrição |
---|---|
8.0.0 | Esta função agora pode ser chamada com apenas um parâmetro. Anteriormente, pelo menos dois parâmetros eram necessários. |
Exemplo #1 Exemplo da array_intersect_key()
<?php
$array1 = array('azul' => 1, 'vermelho' => 2, 'verde' => 3, 'roxo' => 4);
$array2 = array('verde' => 5, 'azul' => 6, 'amarelo' => 7, 'ciano' => 8);
var_dump(array_intersect_key($array1, $array2));
?>
O exemplo acima produzirá:
array(2) { ["azul"]=> int(1) ["verde"]=> int(3) }
Em nosso exemplo você pode ver que somente as chaves 'azul'
e 'verde'
estão presentes em ambos os array e assim são retornados. Também note que os valores das chaves 'azul'
e 'verde'
diferem nos dois arrays. A combinação ocorre porque somente as chaves são verificadas. Os valores retornados são do array
.
As duas chaves do par key => value
são considerados iguais somente se (string) $key1 === (string) $key2
. Em outras palavras um verificação do tipo é executada, então a representação string precisa ser a mesma.