首页 > 解决方案 > 如何在 Pandas 堆积条形图中设置类别的顺序

问题描述

我正在尝试使用自定义排序类别(以不同颜色显示的元素)制作 Pandas 条形图。这是我的代码,我希望类别从下到上的顺序遵循“catorder”:

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt


df2 = pd.DataFrame({"series":["ser1","ser1","ser1", "ser2", "ser2","ser2"], 
                    "cate":["aatu","boiler","heat pump","aatu","boiler","heat pump"],
                    "val": [6,15,24,7,15, 21] })


ac2 = pd.pivot_table(df2, values = "val", index = "series", columns = "cate")

catorder= ["heat pump","aatu","boiler"]
ac2.columns = pd.CategoricalIndex(ac2.columns.values, 
                                 ordered=True, 
                                 categories=catorder)
ac2.sort_index(axis = 1)


fig = plt.figure(figsize=(6,3.5))
ax1 = fig.add_subplot(111)
ac2.plot.bar(stacked=True, ax = ax1)

plt.show()

问题是它不起作用。类别仍按字母顺序排列。任何想法如何完成这个常见的任务?

标签: pythonpandasmatplotlib

解决方案


您需要在绘图之前对数据进行排序:

ac2.sort_index(axis=1).plot.bar(stacked=True, ax = ax1)

输出:

在此处输入图像描述


推荐阅读