En este post vamos a ver cómo eliminar los elementos duplicados de un arreglo, array o lista usando el lenguaje de programación Python.
Al final vamos a definir una función que recibirá una lista que puede tener elementos repetidos pero siempre devolverá un arreglo sin los repetidos, sin importar si los datos son primitivos u objetos.
Básicamente vamos a hacer una lista con los elementos únicos de otra lista. Por cierto, aquí usaré array, arreglo y lista como sinónimos.
Vamos a crear una nueva lista vacía en donde no habrá repetidos, y después recorrer la lista original.
Por cada elemento de la lista original vamos a ver si el elemento ya existe en la lista sin repetidos. Si ya existe, no hacemos nada y seguimos recorriendo, pero en caso de que no exista, lo agregamos a esa lista.
Al final regresamos el arreglo sin duplicados / repetidos.
Vamos a ver el primer ejemplo para tipos de datos primitivos (no objetos). En este caso la función queda así:
"""
https://parzibyte.me/blog
"""
def eliminar_duplicados(lista):
nueva_lista = []
for elemento in lista:
if not elemento in nueva_lista:
nueva_lista.append(elemento)
return nueva_lista
Se está siguiendo el algoritmo tal como lo dije, declaramos la lista sin repetidos en la línea 7, recorremos la original en la línea 8 y en caso de que el elemento no esté en el arreglo sin duplicados lo agregamos con append.
El modo de uso es el siguiente:
lista = [1, 1, 1, 3, 3, 3, 4, 4, 4, 90, 2, 10, 60, 2, 60]
sin_duplicados = eliminar_duplicados(lista)
print("Original: ")
print(lista)
print("Sin repetidos")
print(sin_duplicados)
La salida ya la has visto en la imagen que está junto al encabezado de esta sección.
Solo una pequeña nota por aquí. Como pudiste ver, usamos el operador in
propio de Python para saber si el elemento ya está dentro de la lista. Este operador también funciona con objetos, pero debemos sobrescribir a __eq__
.
Si no sabes de lo que hablo y quieres entenderlo, ya le he dedicado un post completo al tema.
La función es exactamente la misma, pero ahora trabajamos con objetos. Para este caso específico he creado una clase de ejemplo y rellenado un arreglo con instancias de la misma:
"""
https://parzibyte.me/blog
"""
class Juego:
def __init__(self, nombre, precio):
self.nombre = nombre
self.precio = precio
# Método que nos dice si un objeto es igual a otro
# https://parzibyte.me/blog/2021/04/01/comparar-objetos-python/
def __eq__(self, otro_juego):
return otro_juego.nombre == self.nombre and otro_juego.precio == self.precio
def __str__(self):
return f"{self.nombre}, {self.precio}"
def eliminar_duplicados(lista):
nueva_lista = []
for elemento in lista:
if not elemento in nueva_lista:
nueva_lista.append(elemento)
return nueva_lista
# Fíjate que Cuphead aparece 2 veces (con el mismo precio y nombre) y Hollow Knight también
lista = [Juego("Cuphead", 180), Juego("Cuphead", 180), Juego(
"Resident Evil 2", 430), Juego("Hollow Knight", 150), Juego("Cuphead", 180), Juego("Hollow Knight", 150)]
sin_duplicados = eliminar_duplicados(lista)
print("===\nOriginal: ===\n")
for elemento in lista:
print(str(elemento))
print("===\nSin repetidos===\n")
for elemento in sin_duplicados:
print(str(elemento))
La salida ya las has visto en la imagen anterior.
Para terminar te dejo con más artículos de programación en Python.
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
me podrían explicar porque esto no funciona
miLista = [1, 2, 4, 4, 1, 4, 2, 6, 2, 9]
miLista.sort()
for i in range (len(miLista)-1):
if miLista[i] == miLista[i+1]:
del miLista[i]
print("La lista solo con elementos únicos:")
print(miLista)