File size: 7,139 Bytes
d83312b
 
feb9ddc
 
d83312b
feb9ddc
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
---
license: mit
language:
- es
---
# 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