python

Python – Eliminar repetidos de lista

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.

Algoritmo general

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.

Remover duplicados de arreglo con Python

Eliminar repetidos de arreglo en Python – datos primitivos

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.

Para el caso de los objetos

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.

Ejemplo para eliminar objetos repetidos de arreglo

Remover objetos repetidos de lista en Python

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.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

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)

Entradas recientes

Desplegar PWA creada con Vue 3, Vite y SQLite3 en Apache

Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…

3 días hace

Arquitectura para wasm con Go, Vue 3, Pinia y Vite

En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…

3 días hace

Vue 3 y Vite: crear PWA (Progressive Web App)

En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…

3 días hace

Errores de Comlink y algunas soluciones

Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…

3 días hace

Esperar promesa para inicializar Store de Pinia con Vue 3

En este artículo te voy a enseñar cómo usar un "top level await" esperando a…

3 días hace

Solución: Apache – Server unable to read htaccess file

Ayer estaba editando unos archivos que son servidos con el servidor Apache y al visitarlos…

3 días hace

Esta web usa cookies.