Spaces:
Sleeping
Sleeping
File size: 5,221 Bytes
6a2e1f1 |
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 151 152 153 154 155 156 157 158 159 160 161 162 163 |
import streamlit as st import pandas as pd import numpy as np import matplotlib.pyplot as plt import yfinance as yf # Başlık st.title('Portföy Yönetim Aracı') # Kullanıcıdan hisse senedi sembollerini alın st.sidebar.header("Portföy Bilgileri") symbols = st.sidebar.text_input("Hisse Senedi Sembolleri (Virgülle Ayırın)", "AAPL, MSFT, TSLA") symbols = [sym.strip().upper() for sym in symbols.split(',')] # Kullanıcıdan her hisse senedi için yatırım miktarını alın amounts = {} for sym in symbols: amount = st.sidebar.number_input(f'{sym} için yatırım miktarı girin :', min_value=0, value=1000) amounts[sym] = amount def load_data(symbols): data = {} for sym in symbols: # Verileri indirin ve sadece 'Close' (kapanış) fiyatlarını alın data[sym] = yf.download(sym, start="2022-01-01", end="2024-01-01")['Close'] # Eğer data sözlüğü boştur veya yanlışsa, uygun hata mesajı döndür if not data: raise ValueError("Veri çekilmedi. Lütfen hisse senedi sembollerini kontrol edin.") # Her bir sembol için kapanış fiyatlarını içeren DataFrame'i oluşturun df = pd.DataFrame(data) # Eğer df içeriği eksikse veya bir sorun varsa, uygun hata mesajı döndür if df.empty: raise ValueError("Oluşturulan DataFrame boş.") return df # Veriyi yükleyin df = load_data(symbols) # Portföy performansını hesaplayın total_investment = sum(amounts.values()) # Toplam yatırım miktarını hesaplayın portfolio_value = df.iloc[-1] * pd.Series(amounts) # Her bir hissenin mevcut değerini hesaplayın portfolio_value_total = portfolio_value.sum() # Portföyün toplam değerini hesaplayın st.write(f"Toplam yatırım miktarı: ${total_investment:.2f}") st.write(f"Her bir hissenin mevcut değeri:") st.write(portfolio_value) st.write(f"Portföyün toplam değeri: ${portfolio_value_total:.2f}") # Plotly ile Etkileşimli Grafikler import plotly.express as px # Interaktif Hisse Fiyat Grafiği fig = px.line(df, title = "Hisse Senedi Fiyatları") st.plotly_chart(fig) # Portföy Dağıılım Grafiği fig = px.bar(x = amounts.keys(), y = portfolio_value, labels = {"x" : 'Yatırım Araçları', 'y' : 'Portföy Değeri' }) st.plotly_chart(fig) # Getiri Hesaplama daily_returns = df.pct_change().dropna() st.write("Günlük Getiriler:") st.dataframe(daily_returns) # Aylık ve Yıllık Getiriler monthly_returns = df.resample('M').ffill().pct_change().dropna() annual_returns = df.resample('Y').ffill().pct_change().dropna() st.write("Aylık Getiriler:") st.dataframe(monthly_returns) st.write("Yıllık Getiriler:") st.dataframe(annual_returns) # Risk Analizi # # Volatilite Hesaplama volatility = daily_returns.std() * np.sqrt(252) # Yıllık Volatilite st.write("Volatilite (Yıllık) : " , "Volatilite, bir varlığın fiyatındaki dalgalanmaların büyüklüğünü ifade eder. Bu kod, günlük volatiliteyi yıllık volatiliteye çevirir ve bunu gösterir.", "Volatilite 0.29, yıllık bazda bir varlığın fiyatında %29'luk bir dalgalanma bekleyebileceğinizi ifade eder. Bu, varlığın yıllık getirisinin ortalamadan %29 sapma gösterebileceği anlamına gelir.") st.dataframe(volatility) # Portföyün beta değeri beta = daily_returns.cov() / daily_returns.var() st.write("Beta Değeri :" , " bir varlığın veya portföyün piyasa ile olan ilişkisini ölçer. Piyasa riskine karşı duyarlılığı anlamak için kullanılır.", "Özetle, beta değeri 0,70 olan bir varlık, piyasa hareketlerine kıyasla daha az dalgalanma gösterir." , "Yani, bu varlık, piyasanın genel hareketlerinden daha az etkilenir ve daha stabil bir performans sergiler. Bu durum, yatırımcılar için daha düşük riskli bir yatırım anlamına gelir.") st.dataframe(beta) # Hareketli Ortalama window_size = st.sidebar.slider("Hareketli Ortalama Penceresi (Gün)", 5, 100, 20) moving_avg = df.rolling(window=window_size).mean() st.write(f"{window_size} Günlük Hareketli Ortalama:") st.line_chart(moving_avg) # Filtreler start_date = st.sidebar.date_input("Başlangıç Tarihi", pd.to_datetime("2023-01-01")) end_date = st.sidebar.date_input("Bitiş Tarihi", pd.to_datetime("2024-01-01")) # Tarih aralığına göre veriyi filtrele start_date = pd.to_datetime(start_date) end_date = pd.to_datetime(end_date) z if start_date < end_date: filtered_data = df[(df.index >= start_date) & (df.index <= end_date)] st.line_chart(filtered_data) else: st.error("Başlangıç tarihi bitiş tarihinden sonra olmamalıdır.") # Monte Carlo Simülasyonu mean_returns = daily_returns.mean() # Ortalama günlük getiriler simulations = 1000 simulation_df = pd.DataFrame() for x in range(simulations): simulated_prices = [] for symbol in symbols: price_series = [df[symbol].iloc[-1]] for _ in range(365): # 1 yıl price_series.append(price_series[-1] * (1 + np.random.normal(mean_returns[symbol], volatility[symbol]))) simulated_prices.append(price_series) simulation_df[x] = pd.Series([np.sum(sim) for sim in zip(*simulated_prices)]) st.line_chart(simulation_df) |