I would like to choose a subsection from a selection.
I have a dataframe like the following.
df = pd.DataFrame()
df['People'] = ['Eva', 'John', 'Paul','Mr a', 'Miss b', 'Mrs c' ]
df['Type'] = ['Students', 'Students', 'Students', 'Teachers', 'Teachers', 'Teachers']
Let say we have Student and Teachers.
select = Select(title="People", options=['Student', 'Teachers' ])
Then we have three students: Eva, John, Paul and three teachers Mr a, Miss b and Mrs c
How can we create a second selection select2 that choose Eva, John, Paul if we select teachers and Mr a, Miss b and Mrs c if we select Teachers.
select2 = Select(title="Selected", options=[ (`Eva`, `John`, `Paul`), (Mr a`, `Miss b`, `Mrs c`)] ])
This what I have in mind
select_data = Select(title="Type", options=['None', 'Students', 'Teachers' ], value = '')
dynamic_select = Select(title = 'People', value = '' ,
options = ['None','Eva', 'John', 'Paul','Mr a', 'Miss b', 'Mrs c' ] )
controls = widgetbox(select_data, dynamic_select)
layout = column(row(controls))
def update_layout(attr, old, new):
if select_data.value == 'Students':
dynamic_select = Select(title = 'People', value = '', options = ['Eva', 'John', 'Paul'])
if select_data.value == 'Teachers':
dynamic_select = Select(title = 'People', value = '', options = ['Mr a', 'Miss b', 'Mrs c'])
if select_data.value == 'None':
dynamic_select = Select(title = 'People', value = '', options = ['None'])
select_data.on_change('value', update_layout)
dynamic_select.on_change('value', update_layout)
curdoc().add_root(layout)
