rendiamola una funzione grazie

This commit is contained in:
2025-06-23 12:23:25 +02:00
parent 2fe8df9db2
commit 0e82f4b084

View File

@@ -97,34 +97,35 @@ path_export_hourly = path_export.replace('.csv', '_hourly.csv')
# Esporta il file orario
df_hourly = export_hourly_pv_productivity(result_ac_energies_to_csv_df, path_export_hourly)
# Carica il file CSV orario
df = pd.read_csv('files/gen_pv/output_gen_pv_hourly.csv', index_col=0, parse_dates=True)
def genera_giornaliero():
# Carica il file CSV orario
df = pd.read_csv('files/gen_pv/output_gen_pv_hourly.csv', index_col=0, parse_dates=True)
# Raggruppa per giorno e somma la produzione
df_daily = df.resample('D').sum()
# Raggruppa per giorno e somma la produzione
df_daily = df.resample('D').sum()
# Crea il grafico giornaliero
fig = px.line(
# Crea il grafico giornaliero
fig = px.line(
df_daily,
x=df_daily.index,
y='gen_pv_100_kWp',
title='Produttività Fotovoltaica Giornaliera',
labels={'gen_pv_100_kWp': 'Energia [kWh]', 'index': 'Data'}
)
fig.show()
)
fig.show()
# Raggruppa per mese e somma la produzione
df_monthly = df.resample('M').sum()
df_monthly['Mese'] = df_monthly.index.strftime('%B %Y') # Nome mese e anno
# Raggruppa per mese e somma la produzione
df_monthly = df.resample('M').sum()
df_monthly['Mese'] = df_monthly.index.strftime('%B %Y') # Nome mese e anno
# Estrai tutte le date disponibili (solo la parte di data, senza ora)
date_options = df.index.normalize().unique()
# Estrai tutte le date disponibili (solo la parte di data, senza ora)
date_options = df.index.normalize().unique()
# Crea una lista di grafici, uno per ogni giorno
fig = go.Figure()
# Crea una lista di grafici, uno per ogni giorno
fig = go.Figure()
for date in date_options:
for date in date_options:
daily_data = df[df.index.normalize() == date]
fig.add_trace(
go.Scatter(
@@ -135,12 +136,12 @@ for date in date_options:
)
)
# Rendi visibile solo il primo giorno all'avvio
fig.data[0].visible = True
# Rendi visibile solo il primo giorno all'avvio
fig.data[0].visible = True
# Crea i pulsanti per il menu a tendina
buttons = []
for i, date in enumerate(date_options):
# Crea i pulsanti per il menu a tendina
buttons = []
for i, date in enumerate(date_options):
visible = [False] * len(date_options)
visible[i] = True
buttons.append(
@@ -152,7 +153,7 @@ for i, date in enumerate(date_options):
)
)
fig.update_layout(
fig.update_layout(
updatemenus=[
dict(
active=0,
@@ -166,9 +167,8 @@ fig.update_layout(
title=f"Produttività Fotovoltaica Oraria - {date_options[0].date()}",
xaxis_title="Ora",
yaxis_title="Energia [kWh]"
)
fig.show()
)
fig.show()
if joePlaying:
joe.terminate()