首页 > 解决方案 > 将 Pandas pivot_table 子绘制到 matplotlib 图形中会创建一个新图形

问题描述

我正在尝试使用以下代码在一个图中创建两个条形图:

import matplotlib.pyplot as plt
import pandas as pd

df = read_csv(...)

temp1 = df['Credit_History'].value_counts(ascending=True)
temp2 = df.pivot_table(values='Loan_Status',index=['Credit_History'],aggfunc=lambda x: x.map({'Y':1,'N':0}).mean())

fig = plt.figure(figsize=(8,4))
ax1 = fig.add_subplot(121)
temp1.plot(kind='bar')

ax2 = fig.add_subplot(122)
temp2.plot(kind = 'bar')

该图设置正确,创建了子图,并绘制了 temp1,但是当我尝试绘制 temp2(数据透视表)时,它会在我身上创建一个新图,而不是绘制到第二个子图上。这似乎只发生在 pivot_table 上。我能够在两个子图上绘制 temp1 两次,即使我尝试先绘制 temp2 它仍然会创建一个新图形。

这是正在发生的事情的屏幕截图:

多图截图 它没有在图 1 的空子图中创建 pivot_table 图,而是创建了一个新的图 2。

标签: pythonpandasmatplotlib

解决方案


可能是因为您将pandas Seriestemp1 from value_countscall)图和pandas DataFrametemp2 form pivot_tablecall)图配对。由于您的数据透视表生成单列数据框,因此请考虑squeeze()将数据框向下转换为一维系列。然后像往常一样从那里绘制:

temp1 = df['Credit_History'].value_counts(ascending=True).sort_index()

temp2 = df.pivot_table(values='Loan_Status', index='Credit_History',
                       aggfunc=lambda x: x.map({'Y':1,'N':0}).mean())
temp2 = temp2.squeeze()

下面用随机数据演示,希望df复制您的原始数据结构:

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

np.random.seed(42518)   # SEED FOR RANDOM REPRODUCIBILITY
df = pd.DataFrame({'Credit_History': np.random.choice(['debt', 'credit'], 50),
                   'Loan_Status': np.random.choice(['Y', 'N'],50),
                   'Amount': abs(np.random.randn(50))*1000
                  }, columns = ['Credit_History','Loan_Status','Amount'])

temp1 = df['Credit_History'].value_counts(ascending=True).sort_index()

temp2 = df.pivot_table(values='Loan_Status', index='Credit_History',
                       aggfunc=lambda x: x.map({'Y':1,'N':0}).mean())
temp2 = temp2.squeeze()

fig = plt.figure(figsize=(8,4))

ax1 = fig.add_subplot(121)
temp1.plot(kind = 'bar')

ax2 = fig.add_subplot(122)
temp2.plot(kind = 'bar')

plt.show()

绘图输出


推荐阅读