Importar las librer铆as necesarias
import pandas as pd import numpy as np import matplotlib.pyplot as plt import requests import json
Definir los ETFs y las acciones que queremos analizar
etfs = ["SPY", "EEM", "GLD", "QQQ", "IWM"] acciones = ["AAPL", "AMZN", "MSFT", "TSLA", "GOOG"]
Definir las fechas de inicio y fin del an谩lisis
inicio = "2020-01-01" fin = "2024-02-17"
Definir la tasa de descuento para el VPN y la TIR
tasa = 0.05
Definir la funci贸n para obtener los datos de Yahoo Finance
def obtener_datos(simbolo, inicio, fin):
Construir la url de la API de Yahoo Finance
Hacer la petici贸n y obtener la respuesta
respuesta = requests.get(url)
Convertir la respuesta en un dataframe de pandas
datos = pd.read_csv(respuesta.text, parse_dates=["Date"], index_col="Date")
Devolver el dataframe
return datos
Crear un diccionario vac铆o para almacenar los dataframes de los ETFs y las acciones
dataframes = {}
Iterar por cada ETF y obtener sus datos
for etf in etfs:
Obtener los datos del ETF
datos = obtener_datos(etf, inicio, fin)
A帽adir el dataframe al diccionario con el s铆mbolo del ETF como clave
dataframes[etf] = datos
Iterar por cada acci贸n y obtener sus datos
for accion in acciones:
Obtener los datos de la acci贸n
datos = obtener_datos(accion, inicio, fin)
A帽adir el dataframe al diccionario con el s铆mbolo de la acci贸n como clave
dataframes[accion] = datos
Definir la funci贸n para calcular el VPN de una inversi贸n
def calcular_vpn(flujos, tasa):
Inicializar el VPN con el valor del flujo inicial
vpn = flujos[0]
Iterar por cada flujo posterior al inicial
for i in range(1, len(flujos)): # Actualizar el VPN con el valor del flujo actualizado vpn += flujos[i] / (1 + tasa) ** i
Devolver el VPN
return vpn
Definir la funci贸n para calcular la TIR de una inversi贸n
def calcular_tir(flujos):
Usar la funci贸n np.irr de numpy para calcular la TIR
tir = np.irr(flujos)
Devolver la TIR
return tir
Definir la funci贸n para calcular el ROI de una inversi贸n
def calcular_roi(ganancia, costo):
Calcular el ROI como la relaci贸n entre la ganancia y el costo
roi = ganancia / costo
Devolver el ROI
return roi
Crear un diccionario vac铆o para almacenar las m茅tricas de los ETFs y las acciones
metricas = {}
Iterar por cada ETF y calcular sus m茅tricas
for etf in etfs:
Obtener el dataframe del ETF
datos = dataframes[etf]
Calcular el precio inicial y final del ETF
precio_inicial = datos["Adj Close"][0] precio_final = datos["Adj Close"][-1]
Calcular el dividendo total del ETF
dividendo_total = datos["Dividends"].sum()
Calcular el flujo inicial y final de la inversi贸n en el ETF
flujo_inicial = -precio_inicial flujo_final = precio_final + dividendo_total
Calcular el VPN, la TIR y el ROI de la inversi贸n en el ETF
vpn = calcular_vpn([flujo_inicial, flujo_final], tasa) tir = calcular_tir([flujo_inicial, flujo_final]) roi = calcular_roi(flujo_final, -flujo_inicial)
A帽adir las m茅tricas al diccionario con el s铆mbolo del ETF como clave
metricas[etf] = {"VPN": vpn, "TIR": tir, "ROI": roi}
Iterar por cada acci贸n y calcular sus m茅tricas
for accion in acciones:
Obtener el dataframe de la acci贸n
datos = dataframes[accion]
Calcular el precio inicial y final de la acci贸n
precio_inicial = datos["Adj Close"][0] precio_final = datos["Adj Close"][-1]
Calcular el dividendo total de la acci贸n
dividendo_total = datos["Dividends"].sum()
Calcular el flujo inicial y final de la inversi贸n en la acci贸n
flujo_inicial = -precio_inicial flujo_final = precio_final + dividendo_total
Calcular el VPN, la TIR y el ROI de la inversi贸n en la acci贸n
vpn = calcular_vpn([flujo_inicial, flujo_final], tasa) tir = calcular_tir([flujo_inicial, flujo_final]) # Corregir el par茅ntesis roi = calcular_roi(flujo_final, -flujo_inicial)
A帽adir las m茅tricas al diccionario con el s铆mbolo de la acci贸n como clave # Corregir la asignaci贸n
metricas[accion] = {"VPN": vpn, "TIR": tir, "ROI": roi}
Convertir el diccionario de m茅tricas en un dataframe de pandas # Corregir la conversi贸n
metricas = pd.DataFrame(metricas)
Mostrar el dataframe de m茅tricas
print(metricas)
Importar la librer铆a plotly para crear gr谩ficos interactivos
import plotly.express as px
Crear un gr谩fico de barras que muestre el VPN de cada ETF y acci贸n
fig1 = px.bar(metricas.T, x=metricas.T.index, y="VPN", title="VPN de los ETFs y las acciones")
Mostrar el gr谩fico
fig1.show()
Crear un gr谩fico de barras que muestre la TIR de cada ETF y acci贸n
fig2 = px.bar(metricas.T, x=metricas.T.index, y="TIR", title="TIR de los ETFs y las acciones")
Mostrar el gr谩fico
fig2.show()
Crear un gr谩fico de barras que muestre el ROI de cada ETF y acci贸n
fig3 = px.bar(metricas.T, x=metricas.T.index, y="ROI", title="ROI de los ETFs y las acciones")
Mostrar el gr谩fico
fig3.show()
Usar un gpt para generar el texto que explique los gr谩ficos
texto = """ Este bashboard muestra las m茅tricas de inversi贸n de los ETFs y las acciones que has elegido, desde el 1 de enero de 2020 hasta el 17 de febrero de 2024. Las m茅tricas son el VPN, la TIR y el ROI, que miden la rentabilidad, el riesgo y el beneficio de cada inversi贸n.
El primer gr谩fico muestra el VPN de cada ETF y acci贸n, que es la diferencia entre el valor actual de los ingresos futuros y el valor actual de los costos futuros de una inversi贸n. Un VPN positivo indica que la inversi贸n es rentable, mientras que un VPN negativo indica que la inversi贸n es deficitaria. Como se puede observar, todos los ETFs y acciones tienen un VPN positivo, lo que significa que han generado m谩s ingresos que costos en el periodo analizado. El ETF que tiene el mayor VPN es el SPY, que replica el 铆ndice S&P 500, seguido por el QQQ, que replica el 铆ndice Nasdaq 100. La acci贸n que tiene el mayor VPN es la de Tesla, que ha tenido un crecimiento espectacular en los 煤ltimos a帽os.
El segundo gr谩fico muestra la TIR de cada ETF y acci贸n, que es la tasa de descuento que hace que el VPN de una inversi贸n sea igual a cero. La TIR representa la rentabilidad anual de una inversi贸n. Una TIR mayor que el costo de capital indica que la inversi贸n es rentable, mientras que una TIR menor que el costo de capital indica que la inversi贸n es deficitaria. Como se puede observar, todos los ETFs y acciones tienen una TIR mayor que el costo de capital, que hemos asumido que es del 5%, lo que significa que han sido inversiones rentables en el periodo analizado. El ETF que tiene la mayor TIR es el GLD, que replica el precio del oro, seguido por el IWM, que replica el 铆ndice Russell 2000. La acci贸n que tiene la mayor TIR es la de Tesla, que ha tenido una rentabilidad impresionante en los 煤ltimos a帽os.
El tercer gr谩fico muestra el ROI de cada ETF y acci贸n, que es la