• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad
    • Tiendas afiliadas
      • AliExpress
      • Amazon
      • Banggood
      • GeekBuying
      • Lenovo

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • Python
  • Pandas
  • NumPy
  • Matlab
  • Julia
  • Excel
  • IA Generativa

Introducción a la programación funcional en Python

junio 3, 2019 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 4 minutos

A la hora de crear código en Python es habitual utilizar un paradigma imperativo. Indicando de forma detallada la secuencia de tareas que el ordenador debe de ejecutar. Otro paradigma que con el que se puede escribir código en Python es la programación funcional. Un paradigma que se basa en la utilización de funciones, que permite obtener código más fácil de probar y entender. En esta entrada se van a mostrar los fundamente de la programación funcional en Python.

Funciones lambda

Las funciones lambda son pequeñas funciones anónimas de una sola línea que se pueden definir sobre la marcha o asignar a una variable. Anónimas en el sentido de que en realidad no tiene un nombre. En Python la forma de definir una función es mediante la palabra clave def seguida de un nombre y el listado de parámetros. El cuerpo de la función será el código indexado situado después de esta línea. Para definir una función lambda se utiliza la palabra clave lambda seguida de los parámetros, dos putos y la expresión. Esto es lo que se puede ver en el siguiente ejemplo:

fun = lambda a : 1+a
print(fun(3))    # Resultado: 4

fun = lambda a, b : a+b
print(fun(3, 4)) # Resultado: 7

En la primera función se suma la unidad al parámetro a, mientras que en la segunda se suma los valores de los dos parámetros. Es importante recordar que una función lambda puede tener cualquier número de argumentos, pero siempre debe tener una sola expresión.

Tutorial de Mypy para Principiantes
En Analytics Lane
Tutorial de Mypy para Principiantes

Publicidad


map

La función map de Python permite aplicar una función a una secuencia de elementos como una lista o un diccionario. Es una forma rápida, limpia y, lo que es más importante, legible de realizar la operación. Esto se puede ver en siguiente ejemplo donde se compara el uso de map con for para aplicar una función a un vector.

def square(a):
    return a*a

data = [1, 3, 5]
result = []

# Iterar con for
for i in data:
    result.append(square(i))

print(result)

# Map sobre función
print(list(map(square, data)))

# Map sobre lambda
print(list(map(lambda a: a*a, data)))

En este ejemplo en primer lugar se define una función square que devuelve el cuadrado de argumento. Posteriormente se crea un vector y se aplica la función sobre este utilizando un bucle for. Una vez obtenido el resultado de esta forma se repite la operación utilizando la función map con la que se simplifica la operación. Finalmente se vuelve a realizar la operación con map pero reemplazando la función por una lambda. En todos los casos el resultado obtenido es [1, 9, 25].

Lo que permite apreciar como la utilización de map permite obtener códigos más fáciles de entender que for.

filter

Tal como indica su nombre la función filter permite seleccionar los elementos de una secuencia que verifica un criterio. Criterio que define en una función. filter funciona como map pero solamente devuelve los elementos para los que la función retorna un valor verdadero. En el siguiente ejemplo se crear una función que devuelve verdadero cuando el número es par, posteriormente se utiliza junto a filter para seleccionar los elementos de un vector,

def odd_number(num):

    if num%2 == 0:
        return True
    else:
        return False
    
data = [1, 2, 3, 4, 5, 6, 7, 8, 9]

# Filter sobre función
print(list(filter(odd_number, data)))

# Filter sobre lambda
print(list(filter(lambda x: x%2 == 0, data)))

Al igual que en el caso anterior se muestra un ejemplo utilizando una función y una lambda en filter. En todos los casos el resultado obtenido es [2, 4, 6, 8].

Publicidad


reduce

En el caso de que se desee realizar una cálculo sobre una lista en Python se puede utilizar la función reduce. Al aplicar un cálculo sobre pares de valores en la secuencia de una lista. Por ejemplo, para obtener el producto de los elementos de una lista se puede emplear un bucle for o reduce como se muestra en el siguiente ejemplo:

from functools import reduce

result = 1
data = [1, 3, 5]

# Iterar con for
for i in data:
    result *= i
    
print(result)

print(reduce(lambda a, b: a*b, data))

En ambos casos el resultado obtenido es 15.

A diferencia de las funciones anteriores reduce es necesario importarla de functools.

Conclusiones

Hoy se ha visto una introducción a la programación funcional en Python. Para ello se han visto tres funciones que aplicar funciones sobre conjuntos de datos como map, filter y reduce. La utilización de programación funcional en Python permite generar código más fácil de leer y mantener.

Imágenes: Pixabay (t_watanabe)

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicidad


Publicaciones relacionadas

  • Tutorial de Mypy para Principiantes
  • Semana sin nuevas publicaciones
  • Combinar gráficos con FacetGrid: Cómo analizar tendencias complejas en múltiples paneles con Seaborn
  • Introducción a igraph en R (Parte 6): Centralidad de Katz en grafos
  • Cómo modificar los mensajes de commit en Git
  • Optimización de memoria en Pandas: Usar tipos de datos personalizados para manejar grandes conjuntos de datos
  • Introducción a igraph en R (Parte 7): Centralidad de Bonacich
  • ¡Analytics Lane cumple siete años!
  • Sincronizar múltiples ejes con twinx(): Comparación de datos con diferentes escalas en un solo gráfico con Matplotlib

Publicado en: Python

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Variables globales en Python: Problemas y cómo evitarlos

mayo 12, 2025 Por Daniel Rodríguez

Los valores numéricos en los ordenadores: Entendiendo enteros, flotantes y más

mayo 9, 2025 Por Daniel Rodríguez

Introducción a igraph en R (Parte 8): PageRank

mayo 7, 2025 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Codificación JSON Archivos JSON con Python: lectura y escritura publicado el julio 16, 2018 | en Python
  • Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas publicado el mayo 10, 2019 | en Python
  • Diferencias entre CPU, GPU, TPU y NPU publicado el abril 19, 2023 | en Herramientas
  • Método del codo (Elbow method) para seleccionar el número óptimo de clústeres en K-means publicado el junio 9, 2023 | en Ciencia de datos
  • La distancia de Mahalanobis publicado el abril 19, 2024 | en Ciencia de datos

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.5 (10)

Diferencias entre var y let en JavaScript

Publicidad

Comentarios recientes

  • Daniel Rodríguez en Tutorial de Mypy para Principiantes
  • Javier en Tutorial de Mypy para Principiantes
  • javier en Problemas con listas mutables en Python: Cómo evitar efectos inesperados
  • soldado en Numpy básico: encontrar la posición de un elemento en un Array de Numpy
  • plataformas AéReas en Numpy básico: encontrar la posición de un elemento en un Array de Numpy

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2025 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto