如何解决是否可以根据选择重新排序 altair 中的图表?
我正在尝试创建一个可根据用户输入重新选择的堆积条形图。我知道如何创建选择,但我认为当输入下拉列表更改时不会重新评估表达式。也许这根本不可能?
import pandas as pd
import altair as alt
from io import StringIO
TESTDATA = StringIO("""Nom du film,Synopsis,Son,Décors et Costumes,Qualité tournage,Qualité montage,Jeu des acteurs,Bonus,TOTAL
Chaque seconde compte,6.0,6.67,6.33,7.17,6.5,0.67,7.17
Premier Rôle,7.5,7.0,8.0,0.0,7.5
Diagnostic,6.17,3.67,5.5,5.67,0.17,5.67
The Last Name of John Cage,6.75,4.75,5.75,5.25,0.5,6.25
Photos Souvenirs,4.67,5.83,5.5""")
df_test = pd.read_csv(TESTDATA,sep=",")
value = 'value'
synopsis = 'Synopsis'
sound = 'Son'
costumes = 'Décors et Costumes'
tournage = 'Qualité tournage'
montage = 'Qualité montage'
acteurs = 'Jeu des acteurs'
bonus = 'Bonus'
fields = [synopsis,sound,costumes,tournage,montage,acteurs,bonus]
input_dropdown = alt.binding_select(options=fields)
sort_selection = alt.selection_single(fields=['score'],bind=input_dropdown,name='score to sort by ',init={'score': 'value'})
legend_selection = alt.selection_multi(fields=['column'],bind='legend')
bar_chart = alt.Chart(df_test).transform_fold(fields,as_=['column','value']).mark_bar(size=10).encode(
x=alt.X('Nom du film:N',sort=alt.EncodingSortField(field='value',op='average',order='descending')),y=alt.Y('value:Q'),color=alt.Color('column:N',legend=alt.Legend(orient="left")),tooltip=fields,).properties(width=alt.Step(12)).add_selection(sort_selection,legend_selection)
bar_chart
如果可能的话,我怎样才能做到这一点?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。