vega - 如何在 altair 中链接两个条形图?
问题描述
我在进行相当简单的交互时遇到了麻烦,因为我不太了解 altair 的语言。
假设我有一个包含州、县和人口的数据框。
我想创建一个显示州及其人口的条形图和另一个显示县及其人口的条形图。
单击一个州会在下一个条形图中填充县名及其人口。在第一个图表中单击远离任何州会再次清空县图表。
简单的主/细节或上下文/焦点对图表。
另外,我也不清楚如何调试它。有没有办法将选定的状态打印到控制台?
这是我从维基百科中提取的一些数据(无法共享实际工作数据):
State,County,Land Area
California,Los Angeles, 10510
Illinois,Cook, 2448
Texas,Harris, 4412
Arizona,Maricopa, 23828
California,San Diego, 10895
California,Orange, 2048
Florida,Miami-Dade, 4915
New York,Kings, 183
Texas,Dallas, 2257
New York,Queens, 281
California,Riverside, 18665
California,San Bernardino, 51947
当我单击第一个图表中代表加利福尼亚的条形图时,第二个图表应填充洛杉矶、圣地亚哥、奥兰治、里弗赛德和圣贝纳迪诺。当我在第一个图表中单击纽约时,第二个图表应该填充国王和皇后。
解决方案
我相信这是你想要的。这个想法是在图表上创建一个选择,并使用它来过滤第二个。
import altair as alt
import pandas as pd
from io import StringIO
states_str = """State,County,Land Area
California,Los Angeles, 10510
Illinois,Cook, 2448
Texas,Harris, 4412
Arizona,Maricopa, 23828
California,San Diego, 10895
California,Orange, 2048
Florida,Miami-Dade, 4915
New York,Kings, 183
Texas,Dallas, 2257
New York,Queens, 281
California,Riverside, 18665
California,San Bernardino, 51947
"""
states_df = pd.read_csv(StringIO(states_str))
state_selector = alt.selection_multi(fields=['State'])
chart_states = alt.Chart(states_df).mark_bar().encode(
x=alt.X('State:N'),
y=alt.Y('count():Q')
).add_selection(state_selector)
chart_county = alt.Chart(states_df).mark_bar().encode(
x=alt.X('County:N'),
y=alt.Y('count():Q')
).transform_filter(state_selector)
chart_states | chart_county
未选择任何内容时的图表
推荐阅读
- android - Firebase Crashlytics 不显示事件日志
- javascript - 将操作从 nemespaced vuex 模块映射到组件方法仅适用于 2 种可用语法之一
- python - 为什么'type()'函数没有返回任何东西?
- html - CSS:位置:绝对内部位置:相对未正确定位在溢出-x:可见
- python - 你如何在python中合并两个列表
- javascript - 将状态变量作为参数的 React 组件不会在更新时呈现
- javascript - 在反应js中重定向到主页
- sql - 使用 Pivot 在 SQL Server 中将行转换为列
- c# - ConfigurationChanged 在 Android 中没有被解雇
- java - 用ProgressBar替换ProgressDialog,一半时间不显示