我有以下数据集
我想用某种图表来显示:参数应该位于 X 轴上:确认、死亡、恢复。必须为每个 region_name 定义它们。 Y 轴应该是这些值的总和。我在官方文档中读到了melt()方法,但是不太明白怎么用。
我需要得到这样的东西,只有以下形式。
答案 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"
)