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.
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
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