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.
En mi blog te he enseñado a usar youtube-dl para descargar vídeos con permiso del…
Siguiendo con los tutoriales que consumen la API de los Bots de Telegram con cURL…
En un post previo te enseñé a enviar un mensaje en nombre de un Bot…
En este artículo te voy a mostrar una guía para imprimir en una impresora térmica…
La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…
Hoy te enseñaré cómo enviar un mensaje a un usuario desde un bot de Telegram…
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