(PHP 4 >= 4.0.1, PHP 5, PHP 7, PHP 8)
array_unique — Remove os valores duplicados de um array
Recebe uma entrada array
e retorna um novo array sem valores duplicados.
Note que as chaves são preservadas. Se vários elementos forem iguais sob as flags
fornecidas, então a chave e o valor do primeiro elemento igual serão retidos.
Nota: Dois elementos são considerados iguais se, e somente se,
(string) $elem1 === (string) $elem2
. Em palavras: quando a represetação em string é a mesma, o primeiro elemento será usado.
array
O array de entrada.
flags
O segundo parâmetro opcional flags
pode ser utilizado para modificar o comportamento de comparação usando estes valores:
Flags de tipo de comparação:
SORT_REGULAR
- compara os itens normalmente (não altera tipos)SORT_NUMERIC
- compara itens numericamenteSORT_STRING
- compara itens como stringsSORT_LOCALE_STRING
- compara itens como strings baseado na localidade atual. Retorna o array filtrado.
Versão | Descrição |
---|---|
7.2.0 | Se flags for SORT_STRING , o array anterior foi copiado e os elementos não únicos foram removidos (sem empacotar o array em seguida), mas um novo array é criado ao adicionar os novos elementos. Isto pode resultar em índices numéricos diferentes. |
Exemplo #1 Exemplo de array_unique()
<?php
$input = array("a" => "verde", "vermelho", "b" => "verde", "azul", "vermelho");
$result = array_unique($input);
print_r($result);
?>
O exemplo acima produzirá:
Array ( [a] => verde [0] => vermelho [1] => azul )
Exemplo #2 array_unique() e tipos
<?php
$input = array(4, "4", "3", 4, 3, "3");
$result = array_unique($input);
var_dump($result);
?>
O exemplo acima produzirá:
array(2) { [0] => int(4) [2] => string(1) "3" }
Nota: Note que array_unique() não se destina a funcionar em arrays multidimensionais.