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 este post te quiero compartir un código de C++ para listar y cancelar trabajos…
Gracias a WebAssembly podemos ejecutar código de otros lenguajes de programación desde el navegador web…
Revisando y buscando maneras de imprimir un PDF desde la línea de comandos me encontré…
Esta semana estuve recreando la API del plugin para impresoras térmicas en Android (HTTP a…
Hoy te enseñaré a extraer la cadena base64 de una clave PEM usando una función…
Encender un foco con un Bot de Telegram es posible usando una tarjeta como la…
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