Edit model card

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

url = f"https://query1.finance.yahoo.com/v7/finance/download/{simbolo}?period1={inicio}&period2={fin}&interval=1d&events=history&includeAdjustedClose=true"

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

Downloads last month

-

Downloads are not tracked for this model. How to track
Inference API
Unable to determine this model's library. Check the docs .