Spaces:
Runtime error
Runtime error
Update app.py
Browse files
app.py
CHANGED
@@ -51,7 +51,7 @@ def init_conn():
|
|
51 |
gcservice_account, client, db, DK_seed, FD_seed, MLB_Data = init_conn()
|
52 |
|
53 |
percentages_format = {'Exposure': '{:.2%}'}
|
54 |
-
freq_format = {'Exposure': '{:.2%}', 'Proj Own': '{:.2%}'}
|
55 |
dk_columns = ['SP1', 'SP2', 'C', '1B', '2B', '3B', 'SS', 'OF1', 'OF2', 'OF3', 'salary', 'proj', 'Team', 'Team_count', 'Secondary', 'Secondary_count']
|
56 |
fd_columns = ['P', 'C_1B', '2B', '3B', 'SS', 'OF1', 'OF2', 'OF3', 'UTIL', 'salary', 'proj', 'Team', 'Team_count', 'Secondary', 'Secondary_count']
|
57 |
|
@@ -401,10 +401,10 @@ with tab2:
|
|
401 |
st.session_state.Sim_Winner_Display = Sim_Winner_Frame.copy()
|
402 |
|
403 |
if sim_site_var1 == 'Draftkings':
|
404 |
-
st.session_state.player_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:
|
405 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
406 |
-
elif sim_site_var1 == '
|
407 |
-
st.session_state.player_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:
|
408 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
409 |
st.session_state.player_freq['Freq'] = st.session_state.player_freq['Freq'].astype(int)
|
410 |
st.session_state.player_freq['Position'] = st.session_state.player_freq['Player'].map(maps_dict['Pos_map'])
|
@@ -417,7 +417,7 @@ with tab2:
|
|
417 |
if sim_site_var1 == 'Draftkings':
|
418 |
st.session_state.sp_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:2].values, return_counts=True)),
|
419 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
420 |
-
elif sim_site_var1 == '
|
421 |
st.session_state.sp_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:1].values, return_counts=True)),
|
422 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
423 |
st.session_state.sp_freq['Freq'] = st.session_state.sp_freq['Freq'].astype(int)
|
@@ -428,6 +428,24 @@ with tab2:
|
|
428 |
st.session_state.sp_freq['Edge'] = st.session_state.sp_freq['Exposure'] - st.session_state.sp_freq['Proj Own']
|
429 |
st.session_state.sp_freq['Team'] = st.session_state.sp_freq['Player'].map(maps_dict['Team_map'])
|
430 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
431 |
with st.container():
|
432 |
st.dataframe(st.session_state.Sim_Winner_Frame)
|
433 |
|
@@ -441,6 +459,7 @@ with tab2:
|
|
441 |
data=st.session_state.player_freq.to_csv().encode('utf-8'),
|
442 |
file_name='player_freq_export.csv',
|
443 |
mime='text/csv',
|
|
|
444 |
)
|
445 |
with tab2:
|
446 |
if 'sp_freq' in st.session_state:
|
@@ -450,4 +469,25 @@ with tab2:
|
|
450 |
data=st.session_state.sp_freq.to_csv().encode('utf-8'),
|
451 |
file_name='player_freq_export.csv',
|
452 |
mime='text/csv',
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
453 |
)
|
|
|
51 |
gcservice_account, client, db, DK_seed, FD_seed, MLB_Data = init_conn()
|
52 |
|
53 |
percentages_format = {'Exposure': '{:.2%}'}
|
54 |
+
freq_format = {'Exposure': '{:.2%}', 'Proj Own': '{:.2%}', 'Edge': '{:.2%}'}
|
55 |
dk_columns = ['SP1', 'SP2', 'C', '1B', '2B', '3B', 'SS', 'OF1', 'OF2', 'OF3', 'salary', 'proj', 'Team', 'Team_count', 'Secondary', 'Secondary_count']
|
56 |
fd_columns = ['P', 'C_1B', '2B', '3B', 'SS', 'OF1', 'OF2', 'OF3', 'UTIL', 'salary', 'proj', 'Team', 'Team_count', 'Secondary', 'Secondary_count']
|
57 |
|
|
|
401 |
st.session_state.Sim_Winner_Display = Sim_Winner_Frame.copy()
|
402 |
|
403 |
if sim_site_var1 == 'Draftkings':
|
404 |
+
st.session_state.player_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:10].values, return_counts=True)),
|
405 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
406 |
+
elif sim_site_var1 == 'Fanduel':
|
407 |
+
st.session_state.player_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:9].values, return_counts=True)),
|
408 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
409 |
st.session_state.player_freq['Freq'] = st.session_state.player_freq['Freq'].astype(int)
|
410 |
st.session_state.player_freq['Position'] = st.session_state.player_freq['Player'].map(maps_dict['Pos_map'])
|
|
|
417 |
if sim_site_var1 == 'Draftkings':
|
418 |
st.session_state.sp_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:2].values, return_counts=True)),
|
419 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
420 |
+
elif sim_site_var1 == 'Fanduel':
|
421 |
st.session_state.sp_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,0:1].values, return_counts=True)),
|
422 |
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
423 |
st.session_state.sp_freq['Freq'] = st.session_state.sp_freq['Freq'].astype(int)
|
|
|
428 |
st.session_state.sp_freq['Edge'] = st.session_state.sp_freq['Exposure'] - st.session_state.sp_freq['Proj Own']
|
429 |
st.session_state.sp_freq['Team'] = st.session_state.sp_freq['Player'].map(maps_dict['Team_map'])
|
430 |
|
431 |
+
if sim_site_var1 == 'Draftkings':
|
432 |
+
st.session_state.team_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,12:13].values, return_counts=True)),
|
433 |
+
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
434 |
+
elif sim_site_var1 == 'Fanduel':
|
435 |
+
st.session_state.team_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,11:12].values, return_counts=True)),
|
436 |
+
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
437 |
+
st.session_state.team_freq['Freq'] = st.session_state.team_freq['Freq'].astype(int)
|
438 |
+
st.session_state.team_freq['Exposure'] = st.session_state.team_freq['Freq']/(1000)
|
439 |
+
|
440 |
+
if sim_site_var1 == 'Draftkings':
|
441 |
+
st.session_state.stack_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,13:14].values, return_counts=True)),
|
442 |
+
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
443 |
+
elif sim_site_var1 == 'Fanduel':
|
444 |
+
st.session_state.stack_freq = pd.DataFrame(np.column_stack(np.unique(st.session_state.Sim_Winner_Display.iloc[:,12:13].values, return_counts=True)),
|
445 |
+
columns=['Player','Freq']).sort_values('Freq', ascending=False).reset_index(drop=True)
|
446 |
+
st.session_state.stack_freq['Freq'] = st.session_state.stack_freq['Freq'].astype(int)
|
447 |
+
st.session_state.stack_freq['Exposure'] = st.session_state.stack_freq['Freq']/(1000)
|
448 |
+
|
449 |
with st.container():
|
450 |
st.dataframe(st.session_state.Sim_Winner_Frame)
|
451 |
|
|
|
459 |
data=st.session_state.player_freq.to_csv().encode('utf-8'),
|
460 |
file_name='player_freq_export.csv',
|
461 |
mime='text/csv',
|
462 |
+
key='player_freq'
|
463 |
)
|
464 |
with tab2:
|
465 |
if 'sp_freq' in st.session_state:
|
|
|
469 |
data=st.session_state.sp_freq.to_csv().encode('utf-8'),
|
470 |
file_name='player_freq_export.csv',
|
471 |
mime='text/csv',
|
472 |
+
key='sp_freq'
|
473 |
+
)
|
474 |
+
with tab3:
|
475 |
+
if 'team_freq' in st.session_state:
|
476 |
+
st.dataframe(st.session_state.team_freq.style.background_gradient(axis=0).background_gradient(cmap='RdYlGn').format(percentages_format, precision=2), use_container_width = True)
|
477 |
+
st.download_button(
|
478 |
+
label="Export Exposures",
|
479 |
+
data=st.session_state.team_freq.to_csv().encode('utf-8'),
|
480 |
+
file_name='player_freq_export.csv',
|
481 |
+
mime='text/csv',
|
482 |
+
key='team_freq'
|
483 |
+
)
|
484 |
+
with tab4:
|
485 |
+
if 'stack_freq' in st.session_state:
|
486 |
+
st.dataframe(st.session_state.stack_freq.style.background_gradient(axis=0).background_gradient(cmap='RdYlGn').format(percentages_format, precision=2), use_container_width = True)
|
487 |
+
st.download_button(
|
488 |
+
label="Export Exposures",
|
489 |
+
data=st.session_state.stack_freq.to_csv().encode('utf-8'),
|
490 |
+
file_name='player_freq_export.csv',
|
491 |
+
mime='text/csv',
|
492 |
+
key='stack_freq'
|
493 |
)
|