• 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
  • Laboratorio
    • Estadística
      • Calculadora del Tamaño Muestral en Encuestas
      • Calculadora de estadísticos descriptivos
      • Test de normalidad
      • Calculadora de contrastes de hipotesis
      • Calculadora de tamano del efecto
      • Simulador de Regresión Lineal con Ruido
      • Visualizador de PCA
      • Visualizador de Series Temporales
      • Simulador de Regresión Logística
      • Simulador de K-Means
      • Simulador de DBSCAN
      • Detector de la Ley de Benford
      • Ajuste de Curvas
      • Calculadora de Matrices
    • Probabilidad
      • Calculadora de Probabilidad de Distribuciones
      • Calculadora de Probabilidades de Lotería
      • Simulador del Problema de Monty Hall
      • Simulador de la Estrategia Martingala
    • Finanzas
      • Calculadora de Préstamos e Hipotecas
      • Conversor TIN ↔ TAE
      • Calculadora DCA con ajuste por inflación
      • Calculadora XIRR con Flujos Irregulares
      • Simulador FIRE (Financial Independence, Retire Early)
    • Negocios
      • CLV
      • Scoring
    • Herramientas
      • Formateador / Minificador de JSON
      • Conversor CSV ↔ JSON
      • Comparador y Formateador de Texto y JSON
      • Formateador y Tester de Expresiones Regulares
      • Inspector de JWT
      • Generador y verificador de hashes
      • Codificador / Decodificador Base64 y URL
      • Conversor de bases numericas
      • Conversor de Timestamp Unix
      • Conversor de colores
      • Generador de UUIDs
    • Juegos
      • Tres en Raya
      • Nim con Q-Learning
    • Más
      • Método D’Hondt
      • Generador de Contraseñas Seguras
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad

Analytics Lane

Ciencia e ingeniería de datos aplicada

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

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.

La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)
En Analytics Lane
La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)

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.

Publicidad


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].

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

  • La caverna del consumo, o cómo Greenspan miraba calzoncillos para hacer política monetaria – El bestiario de los indicadores económicos absurdos (parte 1)
  • La vanidad del paisaje, o por qué un becario sale a contar grúas a Manhattan – El bestiario de los indicadores económicos absurdos (parte 2)
  • Augurios deportivos y portadas malditas, o cuando The Economist predice mejor al revés – El bestiario de los indicadores económicos absurdos (parte 3)
  • El Binning en Credit Scoring: El Arte de Discretizar Variables
  • Cómo comparar tendencias con gráficos de líneas en Matplotlib: guía práctica paso a paso
  • Analytics Lane lanza la versión 1.2 del laboratorio con nuevas herramientas de ajuste de curvas y cálculo matricial
  • Subplots en Matplotlib: cómo organizar múltiples gráficos en una sola figura
  • Analytics Lane lanza la versión 1.3 del laboratorio con nuevas herramientas de evaluación de modelos y utilidades prácticas
  • Ley de Benford: cómo detectar datos manipulados con ejemplos reales

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

Noticias

Analytics Lane lanza la versión 1.3 del laboratorio con nuevas herramientas de evaluación de modelos y utilidades prácticas

junio 19, 2026 Por Daniel Rodríguez

Augurios deportivos y portadas malditas, o cuando The Economist predice mejor al revés – El bestiario de los indicadores económicos absurdos (parte 3)

junio 18, 2026 Por Daniel Rodríguez

El Binning en Credit Scoring: El Arte de Discretizar Variables

junio 16, 2026 Por Daniel Rodríguez

Publicidad

Es tendencia

  • 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
  • Diferencias entre CPU, GPU, TPU y NPU publicado el abril 19, 2023 | en Herramientas
  • Histograma generado para el conjunto de datos con la selección automática del número de bins Calcular el número óptimo de bins para un histograma publicado el febrero 25, 2022 | en Ciencia de datos
  • Enviar mensajes de WhatsApp con Python publicado el marzo 7, 2022 | en Python
  • El promedio engañoso: cuando la media no cuenta toda la historia publicado el enero 13, 2026 | 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.1 (11)

Aplicar el método D’Hondt en Excel

Comentarios recientes

  • bif en JSON en bases de datos: cuándo es buena idea y cuándo no
  • bif en Cómo desinstalar Oracle Database 19c en Windows
  • M. Pilar en Cómo eliminar las noticias en Windows 11 y recuperar tu concentración
  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria

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-2026 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto