Introducción
Hoy veremos cómo podemos detectar valores repetidos de arreglo en PHP. Un arreglo es una colección de valores. Analicemos cómo podemos detectar si alguno de ellos existe más de una vez (o si está duplicado o repetido).
Detectar valores repetidos de arreglo en PHP
Esto es muy fácil y el algoritmo es sencillo. Si lo hiciéramos a mano, sería:
- Crear un arreglo temporal
- Recorrer el arreglo original
- En cada iteración, comprobar:
- Si el valor del arreglo no existe en el temporal, se agrega.
- Si ya existe, no se hace nada
- Al final de la iteración obtenemos la longitud de ambos arreglos. Si la del arreglo original es mayor que la del temporal, entonces sí hay repetidos. En caso de que no, pues no.
Afortunadamente no tenemos que hacer nada de esto, ya que PHP proporciona un método que aunque no sirve directamente para detectar duplicados, sí funciona para contar valores únicos.
array_unique al rescate
Como su nombre lo dice, array_unique devuelve un arreglo con valores únicos. Entonces lo llamamos con el arreglo original, esperamos su resultado (que serán valores sin repetirse) y comparamos la longitud. Así:
$arreglo = ["Luis", "Pedro"]; $longitudOriginal = count($arreglo); $unicos = array_unique($arreglo); $longitudDeUnicos = count($arreglo); if($longitudOriginal > $longitudDeUnicos){ echo "¡Hay repetidos!"; }else{ echo "No hay repetidos"; }
La función de arriba está muy explicada, pero se puede simplificar así:
$arreglo = ["Luis", "Pedro"]; if(count($arreglo) > count(array_unique($arreglo))){ echo "¡Hay repetidos!"; }else{ echo "No hay repetidos"; }
Ejemplos de uso
Vamos a probar con este código en donde sí hay repetidos
$arreglo = ["Luis", "Pedro", "Luis"]; if(count($arreglo) > count(array_unique($arreglo))){ echo "¡Hay repetidos!"; }else{ echo "No hay repetidos"; }
La salida es la siguiente:
Ahora probemos con este otro código:
$arreglo = ["Luis", "Pedro", "Roberto"]; if(count($arreglo) > count(array_unique($arreglo))){ echo "¡Hay repetidos!"; }else{ echo "No hay repetidos"; }
La salida dice que no hay repetidos, y efectivamente es así:
Conclusión
Cabe mencionar que también funciona para otros tipos de datos, no sólo para cadenas.
Hola buenos días,
Me podrías orientar, tengo que realizar una consulta a todos mis registros, los tengo en una base de datos en mysql, a través de php debo realizar la consulta y me muestre los registros que esta repetidos , ya lo intente de varias formas pero no logro obtener los registros duplicados, podrías darme una idea de como hacerlo por favor.
Gracias
Hola, si los tienes en una tabla de SQL está fácil. Agrupa tus resultados (con group by) por el valor que se repiten, y selecciona también el count() de cada uno de ellos. Los repetidos tendrán el count en un valor mayor que 1; verifica que hayas seleccionado los correctos y luego haz la misma consulta pero con un delete y listo. No olvides respaldar todo antes. Saludos