【问题标题】:How to add a legend in altair layered plots如何在 altair 分层图中添加图例
【发布时间】:2021-04-20 20:52:44
【问题描述】:

所以我有以下代码:

workload_df = pd.DataFrame({
'index': pd.to_datetime(['01.02.2010', '01.03.2010', '01.04.2010']),
'measure': [100, 90, 120],
'measure_max': [80, 100, 150],
})

measure_max_plot = alt.Chart(workload_df).mark_bar(color = 'lightgreen', text = 'measure_max').encode(
    alt.X('index', title = '', axis = alt.Axis(labelAngle = -45, labelOverlap = False)),
    alt.Y('measure_max', title = '')
)

measure_plot = alt.Chart(workload_df).mark_bar(text = 'measure').encode(
  x = alt.X('index', title = 'X', axis = alt.Axis(labelAngle = -45, labelOverlap = False)), 
  y = alt.Y('measure', title = 'Y'),

  color=alt.condition(
    alt.datum.measure > alt.datum.measure_max,  
    alt.value('red'),     
    alt.value('steelblue')   
  )
)
altair_plot = alt.layer(measure_max_plot, measure_plot)
st.altair_chart(altair_plot, use_container_width=True)

我已经尝试使用以下解决方案添加图例: Add legend to line & bars to Altair chart without using size/color

但总是出现奇怪的错误,或者得到一个没有任何绘图数据的图例。

谁能帮我解决这个问题?

【问题讨论】:

    标签: python altair streamlit


    【解决方案1】:

    为了向图表添加图例,您需要一个图例将代表的编码。例如,以下是添加颜色编码以生成颜色图例的方法:

    measure_max_plot = alt.Chart(workload_df).transform_calculate(
        color='"measure_max"'
    ).mark_bar(text = 'measure_max').encode(
        alt.X('index', title = '', axis = alt.Axis(labelAngle = -45, labelOverlap = False)),
        alt.Y('measure_max', title = ''),
        alt.Color('color:N')
    )
    
    measure_plot = alt.Chart(workload_df).transform_calculate(
      color="datum.measure > datum.measure_max ? 'bigger' : 'smaller'"
    ).mark_bar(text = 'measure').encode(
      x = alt.X('index', title = 'X', axis = alt.Axis(labelAngle = -45, labelOverlap = False)), 
      y = alt.Y('measure', title = 'Y'),
      color = alt.Color('color:N', scale=alt.Scale(range=['red', 'lightgreen', 'steelblue']))
    )
    altair_plot = alt.layer(measure_max_plot, measure_plot)
    

    请注意,默认情况下,色标在两个分层图表之间共享。可以使用Scale & guide resolution API 微调此行为。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2022-08-18
      • 2020-07-23
      • 1970-01-01
      • 1970-01-01
      • 2019-07-27
      • 2020-05-12
      • 2017-08-17
      • 1970-01-01
      相关资源
      最近更新 更多