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).
Esto es muy fácil y el algoritmo es sencillo. Si lo hiciéramos a mano, sería:
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.
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"; }
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í:
Cabe mencionar que también funciona para otros tipos de datos, no sólo para cadenas.
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Esta web usa cookies.
Ver comentarios
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