我正在与我的Seaborn箱线图和直方图(绘制为子图)的两个小格式问题作斗争。
1.两个子图之间的颜色是 * 略有 * 不同,即使编码的颜色是完全相同的。
1.我正试着重新排列图例的顺序,使'A组'出现在'B组'的上面
groupA = [94, 74, 65, 36, 32, 65, 56, 59, 24, 133, 16, 8, 18]
groupB = [1, 1, 1, 1, 2, 7, 7, 10, 15, 16, 17, 17, 19, 29, 31, 32, 43, 43, 44, 47, 56, 64, 64, 80, 81, 87, 103, 121, 121, 121, 187, 197, 236, 292, 319, 8, 12, 12, 14, 14, 15, 16, 16, 20, 20, 33, 36, 37, 37, 44, 46, 48, 51, 51, 54, 57, 72, 74, 95, 103, 103, 107, 134, 199, 216, 228, 254]
f, (ax_boxplot, ax_histogram) = plt.subplots(2, sharex=True, gridspec_kw={'height_ratios': (0.3,0.7)}, figsize=(10,10))
sns.boxplot(data=[groupA, groupB], ax=ax_boxplot, orient='h', palette=['green', 'silver'])
ax_boxplot.tick_params(axis='y', left=False, labelleft=False)
sns.histplot(data=[groupA, groupB], bins=34, binrange=(0,340), palette=['green', 'silver'], alpha=1, edgecolor='black')
ax_histogram.tick_params(axis='both', labelsize=18)
ax_histogram.legend(labels=['groupB', 'groupA'], fontsize=16, frameon=False)
plt.xlabel("Days", fontsize=24, labelpad=20)
plt.ylabel("Count", fontsize=24, labelpad=20)
sns.despine()
到目前为止我所尝试的:
- 颜色:我试着在直方图中将alpha设置为1,但似乎仍然有轻微的差异。
- 对于图例:尝试使用hue_order和handles,但没有任何成功的机会。
3条答案
按热度按时间0x6upsns1#
尝试在调用
boxplot
时使用saturation=1
。除非另有说明,否则饱和度等于0.75
。该文档说:
饱和浮动,可选
绘制颜色的原始饱和度的比例。大色块使用稍微不饱和的颜色通常会看起来更好,但如果希望打印颜色与输入颜色完全匹配,请将该值设置为1。
fiei3ece2#
您的着色问题通常出现在StackOverflow上。例如Avoid Seaborn barplot desaturation of colors、Seaborn chart colors are different from those specified by palette或Inconsistent colours from custom seaborn palette。Seaborn的作者喜欢矩形的去饱和颜色,所以默认情况下启用了这一功能。
Seaborn创建了自己的图例,通常与调用matplotlib的
ax.legend(...)
得到的图例不同。要更改图例的参数,Seaborn有一个sns.move_legend()
函数。move_legend
主要用于更改位置,但您也可以更改其他参数(项目标签除外)。由于“new”位置是一个必需参数,因此可以使用默认值loc='best'
。对于图例中的标签,Seaborn的常用方法是“长格式” Dataframe ,其中一列用作
hue=
。但是Seaborn也支持字典data
。然后,字典的标签用作图例标签。请注意,除非添加
sns.histplot(..., multiple='stack')
(或multiple='dodge'
),否则最后绘制的直方图的条形将隐藏(部分或全部)其他直方图的条形。这可能非常令人困惑(这就是为什么默认设置了一些透明度)。6mw9ycah3#
seaborn
自动添加标签,并处理顺序。pd.DataFrame(data=v, columns=['Days']).assign(Group=group)
用于为每个列表创建 Dataframe ,其中.assign
为数据的名称创建一个名为'Group'
的列。这两个 Dataframe 用pd.concat
组合。df.head(15)