如何在 Altair 中创建分组条形图?我正在尝试以下方法,但它只是并排生成两个图表。
Chart(data).mark_bar().encode(
column='Gender',
x='Genre',
y='Rating',
color='Gender'
)
如何在 Altair 中创建分组条形图?我正在尝试以下方法,但它只是并排生成两个图表。
Chart(data).mark_bar().encode(
column='Gender',
x='Genre',
y='Rating',
color='Gender'
)
分组条形图示例
我展示了Altair 文档中分组条形图的简化示例。您还可以在此处查看完整的文档。
基本上,您必须将 x 轴Gender
(每个子图中的 F 或 M)、y 轴指定为Rating
和Genre
as Column
。
from altair import *
import pandas as pd
# create dataframe
df = pd.DataFrame([['Action', 5, 'F'],
['Crime', 10, 'F'],
['Action', 3, 'M'],
['Crime', 9, 'M']],
columns=['Genre', 'Rating', 'Gender'])
chart = Chart(df).mark_bar().encode(
column=Column('Genre'),
x=X('Gender'),
y=Y('Rating'),
color=Color('Gender', scale=Scale(range=['#EA98D2', '#659CCA']))
).configure_facet_cell(
strokeWidth=0.0,
)
chart.display() # will show the plot
条形图将如下所示
添加轴参数
您只需遵循Axis
文档中的参数即可使绘图看起来更漂亮:
chart = Chart(df).mark_bar().encode(
column=Column('Genre',
axis=Axis(axisWidth=1.0, offset=-8.0, orient='bottom'),
scale=Scale(padding=4.0)),
x=X('Gender', axis=False),
y=Y('Rating', axis=Axis(grid=False)),
color=Color('Gender', scale=Scale(range=['#EA98D2', '#659CCA']))
).configure_facet_cell(
strokeWidth=0.0,
)
chart.display()