1

我有这个数据框:

df = pd.DataFrame({'Segment': {0: 'A', 1: 'B', 2: 'C', 3: 'D'},
 '%Value_S=0': {0: 0.489, 1: 0.429, 2: 0.467, 3: 0.461},
 '%Value_S=1': {0: 0.511, 1: 0.571, 2: 0.533, 3: 0.539},
 '%Total': {0: 0.148, 1: 0.076, 2: 0.3, 3: 0.477}})
df
    Segment  %Value_S=0  %Value_S=1  %Total
0   A        0.489       0.511       0.148
1   B        0.429       0.571       0.076
2   C        0.467       0.533       0.300
3   D        0.461       0.539       0.477

我正在尝试做一个像这样的堆叠条:

在此处输入图像描述

但我需要条形的宽度从%Total. 所以,为了绘制上面的图表,我使用了这个:

z = df.melt(id_vars="Segment", value_vars=["%Value_S=0", "%Value_S=1"])
(ggplot(z, aes(x="Segment", y="value")) + 
  geom_bar(aes(fill="variable"), stat="identity", position="fill"))

如果我添加width参数:

geom_bar(aes(fill="variable", width= df["%Total"]), stat="identity", position="fill"))

它给了我这个错误:

PlotnineError: 'Aesthetics must either be length one, or the same length as the data'

我也尝试了另一种方法:首先绘制宽度,然后我想不出一种方法来绘制其他两个变量。最难的部分是:四个条必须覆盖所有图形(它们之间没有空格)。有任何想法吗?

4

1 回答 1

0

您从融化的数据框 ( ) 中传递了数据,但尝试通过原始数据框 ( )z的一列来调整条形宽度。df您需要%Total在熔化的 df 中包含该列:

z = df.melt(
    id_vars=["Segment", "%Total"],
    value_vars=["%Value_S=0", "%Value_S=1"]
)

然后简单地映射到%Total列的宽度:

from plotnine import geom_bar, ggplot, aes
(
    ggplot(z, aes(x="Segment", y="value"))
    + geom_bar(
        aes(fill="variable", width="%Total"),
        stat="identity", position="fill"
    )
)

产生:

在此处输入图像描述

于 2020-04-11T17:10:41.807 回答