File size: 2,441 Bytes
bdf85f0
 
 
 
 
4a7ecb4
bdf85f0
 
4a7ecb4
 
 
 
 
 
 
 
bdf85f0
 
 
 
 
 
 
 
 
 
 
 
 
 
4a7ecb4
bdf85f0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
7011f36
 
 
 
 
9b49a8b
4a7ecb4
 
 
7011f36
 
 
 
 
 
 
 
 
 
 
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
import yfinance as yf
import pandas as pd
import matplotlib.pyplot as plt
from prophet import Prophet
import gradio as gr
from datetime import datetime

def previsao_precos(ticker, start_date, end_date, future_date):
    # Converter as datas de string para datetime
    try:
        start_date = pd.to_datetime(start_date)
        end_date = pd.to_datetime(end_date)
        future_date = pd.to_datetime(future_date)
    except ValueError:
        return "Erro: Verifique o formato das datas. Use YYYY-MM-DD.", None

    # Obter dados históricos
    data = yf.download(ticker, start=start_date, end=end_date)
    data.reset_index(inplace=True)
    data = data[['Date', 'Close']]
    data.columns = ['ds', 'y']

    if data.empty:
        return "Não foram encontrados dados para o intervalo de datas especificado.", None

    # Ajustar o modelo Prophet
    model = Prophet()
    model.fit(data)

    # Fazer previsões
    future = model.make_future_dataframe(periods=(future_date - data['ds'].max()).days, freq='B')
    forecast = model.predict(future)

    # Criar gráfico
    plt.figure(figsize=(12, 6))
    plt.plot(data['ds'], data['y'], label='Preço de Fechamento Real', color='blue')
    plt.plot(forecast['ds'], forecast['yhat'], label='Previsão de Preço de Fechamento', color='orange', linestyle='--')
    plt.fill_between(forecast['ds'], forecast['yhat_lower'], forecast['yhat_upper'], color='orange', alpha=0.2)
    plt.title(f'Previsão de Preço de Fechamento de {ticker} até {future_date}')
    plt.xlabel('Data')
    plt.ylabel('Preço de Fechamento')
    plt.xticks(rotation=45)
    plt.legend()
    plt.grid()

    plt.savefig('grafico.png')
    plt.close()

    return forecast.tail(10).to_string(), 'grafico.png'

# Definir a interface Gradio
iface = gr.Interface(
    fn=previsao_precos,
    inputs=[
        gr.Textbox(label="Ticker da Ação", value="GOOG"),
        gr.Textbox(label="Data de Início (YYYY-MM-DD)", value="2019-10-19"),
        gr.Textbox(label="Data de Fim (YYYY-MM-DD)", value="2024-10-19"),
        gr.Textbox(label="Data Futura para Previsão (YYYY-MM-DD)", value="2029-10-19")
    ],
    outputs=[
        gr.Textbox(label="Tabela de Previsões"),
        gr.Image(label="Gráfico de Previsão")
    ],
    title="Previsão de Preço de Ações com Prophet",
    description="Insira o ticker da ação e as datas para prever o preço de fechamento."
)

# Iniciar a interface
iface.launch()