Pandas stacked bar chart duplicates colors for lar

2019-04-01 00:33发布

I need to create a stacked bar chart with a large number (10 or so) categories. The problem is that Pandas only provides colors for up to 7 different categories. It sets the remaining colors as blue. How to I ensure that every category has a unique color?

Example:

df = pd.DataFrame(np.abs(np.random.randn(10,10)),columns=['A','B','C','D','E','F','G','H','I','J'], index=range(10))
df.plot(kind='bar',stacked=True,figsize=(20,10))

Produces a bar chart where H,I, and J are not given unique colors.

1条回答
Root(大扎)
2楼-- · 2019-04-01 01:11
In [22]: colors = plt.cm.GnBu(np.linspace(0, 1, 10))

In [23]: df.plot(kind='bar', stacked=True, figsize=(20, 10), color=colors)
Out[23]: <matplotlib.axes._subplots.AxesSubplot at 0x10b792d90>

enter image description here

matplotlib has a bunch of different colormaps to choose from. Just don't use jet.

查看更多
登录 后发表回答