python - 在 Altair 中使用共享选择器/过滤器在不同图表中绘制两个数据框
问题描述
我有两个熊猫数据框data
,并且data_queue
具有包含相似数据的相同结构。前者应绘制为一条线,而后者应绘制为散点图。我需要一个共享选择器来过滤两个图表。在下面的示例中,选择器仅在我删除scatter
.
如何在 Altair 中实现这一点?
注意:我需要最后一个layer
将工具提示、规则、文本等添加到线图中。为了可读性,我在这里省略了那部分。
input_dropdown = alt.binding_select(options=data.koplus_name.unique().tolist())
selection = alt.selection_single(fields=['koplus_name'], bind=input_dropdown, name='Koplus', init={'koplus_name': input_dropdown.options[0]})
line = alt.Chart(data).mark_line().encode(
x=alt.X('yearmonthdatehoursminutes(timestamp)', title='timestamp', scale=alt.Scale(domain=(str(data.timestamp.min()), str(data.timestamp.min() + pd.Timedelta(value=1, unit='D'))))),
y=alt.Y('value', axis=alt.Axis(title=''), scale=alt.Scale(domain=(0, data.value.max()))),
color=alt.Color('variable', legend=alt.Legend(title=None)),
)
scatter = alt.Chart(data_queue).mark_point().encode(
x='green time',
y='value',
)
chart = line + scatter
layer = alt.layer(
chart
).add_selection(
selection
).transform_filter(
selection
).properties(
width=800, height=250
).interactive(bind_y=False)
解决方案
如果您希望数据响应相同的选择,它必须是相同数据源的一部分。您可以在创建图表之前加入 pandas 中的数据集,也可以使用Altair 语法中的Lookup Transform加入数据集。
这是第二种方法的示例,带有一些小数据集:
import numpy as np
import pandas as pd
import altair as alt
df1 = pd.DataFrame({
'x': np.arange(100),
'y': np.random.randn(100).cumsum()
})
df2 = pd.DataFrame({
'x': np.arange(100),
'z': np.random.randn(100).cumsum()
})
selection = alt.selection_interval(encodings=['x'])
base = alt.Chart(df1).transform_lookup(
lookup='x',
from_=alt.LookupData(data=df2, key='x', fields=['z'])
).mark_point(color='steelblue').encode(
x='x:Q',
color=alt.condition(selection, alt.value('steelblue'), alt.value('lightgray'))
)
alt.layer(
base.encode(y='y:Q'),
base.encode(y='z:Q')
).add_selection(
selection
)
推荐阅读
- java - 如何使用 java 1.6 防止 XXE 攻击
- garmin - Connect IQ 开始运行
- typescript - 如何为打字稿中的变量应用通用类型
- git - 如何忽略子 git 存储库,而不是它们的内容
- python - 如何将正则表达式转换为列表
- python - 在scrapy downolader中间件中使用正则表达式
- android - 接口未在片段中调用
- c++ - 在运行时禁用系统错误弹出窗口(DLL 依赖项)
- serverless-framework - 创建自定义无服务器模板时,“ServerlessError: serverless.yml not found”错误
- java - 如何在片段中的方法中膨胀布局