如何为多个字段显示分组条形图? (牵牛星)

时间:2021-04-28 19:44:56

标签: python plot altair

我有以下数据集

enter image description here

我想用某种图表来显示:参数应该位于 X 轴上:确认、死亡、恢复。必须为每个 region_name 定义它们。 Y 轴应该是这些值的总和。我在官方文档中读到了melt()方法,但是不太明白怎么用。

我需要得到这样的东西,只有以下形式。

enter image description here

enter image description here

1 个答案:

答案 0 :(得分:2)

你有宽格式数据;您需要将其转换为长格式数据。您可以使用 melt() 或类似方法在 Pandas 中执行此操作,也可以使用 Altair 的 transform_fold。您可以在 https://altair-viz.github.io/user_guide/data.html#long-form-vs-wide-form-data

中阅读更多相关信息

对于您的数据,它可能如下所示:

import pandas as pd
import altair as alt

data = pd.read_csv('data_from_screenshot.csv')

alt.Chart(data).transform_fold(
  ["confirmed", "deaths", "recovered"],
  as_=["field", "value"]
).mark_bar().encode(
  x="field:N",
  y="sum(value):Q",
  column="region_name:N"
)