从 pandas 数据框制作多个饼图(每行一个)
Making multiple pie charts out of a pandas dataframe (one for each row)
我有一个数据框 (df),显示与各种业务类别相关的情绪:
我的任务是创建饼图,显示每种业务类型的情绪百分比。所以我需要在 matplotlib 中创建一个函数来读取 "Business" 列,然后使用数据框中每一行的每个情感类别构建一个饼图。
我已经制作了条形图,但我对饼图不满意。编辑:这是我的条形图代码:
import pandas as pd
import csv
import matplotlib.pyplot as plt
GraphData = open("barGraph.csv")
df = pd.read_csv('barGraph.csv')
ax = df.plot(kind='bar', title ="Emotions at Various Businesses", figsize=(15, 10), legend=True, fontsize=12)
ax.set_xlabel("Business Type",fontsize=12)
ax.set_ylabel("Strength of Emotion",fontsize=12)
ax.set_xticklabels(['Beauty & Spas', 'Burgers-Restaurants', 'Pizza', 'Mexican Restaurants', 'Modern European-Restaurants', 'Chinese'])
plt.show()
我已经阅读了关于饼图的文档,但它对我来说没有意义,至少因为它涉及从数据帧而不是系列中绘制数据。
有什么建议吗?
考虑数据框df
df = pd.DataFrame(dict(
Business='Beauty & Spas;Burgers-Restaurants;Pizza;Mexican Restaurants;Modern European-Restaurants;Chineese'.split(';'),
aniticipation=[0] * 6,
enjoyment=[6., 1., 6., 33.,150., 19.5],
sad=[1., 2., 1., 3., 13.5, 0.],
disgust=[1, 1, 0, 3, 37, 3],
anger=[1.5, 2., 4., 9., 19., 3.],
surprise=[3, 0, 0, 2, 12, 1],
fear=[0, 1, 1, 9, 22, 1],
trust=[0] * 6
))
您可以像这样创建饼图
fig, axes = plt.subplots(2, 3, figsize=(10, 6))
for i, (idx, row) in enumerate(df.set_index('Business').iterrows()):
ax = axes[i // 3, i % 3]
row = row[row.gt(row.sum() * .01)]
ax.pie(row, labels=row.index, startangle=30)
ax.set_title(idx)
fig.subplots_adjust(wspace=.2)
我有一个数据框 (df),显示与各种业务类别相关的情绪:
我的任务是创建饼图,显示每种业务类型的情绪百分比。所以我需要在 matplotlib 中创建一个函数来读取 "Business" 列,然后使用数据框中每一行的每个情感类别构建一个饼图。
我已经制作了条形图,但我对饼图不满意。编辑:这是我的条形图代码:
import pandas as pd
import csv
import matplotlib.pyplot as plt
GraphData = open("barGraph.csv")
df = pd.read_csv('barGraph.csv')
ax = df.plot(kind='bar', title ="Emotions at Various Businesses", figsize=(15, 10), legend=True, fontsize=12)
ax.set_xlabel("Business Type",fontsize=12)
ax.set_ylabel("Strength of Emotion",fontsize=12)
ax.set_xticklabels(['Beauty & Spas', 'Burgers-Restaurants', 'Pizza', 'Mexican Restaurants', 'Modern European-Restaurants', 'Chinese'])
plt.show()
我已经阅读了关于饼图的文档,但它对我来说没有意义,至少因为它涉及从数据帧而不是系列中绘制数据。
有什么建议吗?
考虑数据框df
df = pd.DataFrame(dict(
Business='Beauty & Spas;Burgers-Restaurants;Pizza;Mexican Restaurants;Modern European-Restaurants;Chineese'.split(';'),
aniticipation=[0] * 6,
enjoyment=[6., 1., 6., 33.,150., 19.5],
sad=[1., 2., 1., 3., 13.5, 0.],
disgust=[1, 1, 0, 3, 37, 3],
anger=[1.5, 2., 4., 9., 19., 3.],
surprise=[3, 0, 0, 2, 12, 1],
fear=[0, 1, 1, 9, 22, 1],
trust=[0] * 6
))
您可以像这样创建饼图
fig, axes = plt.subplots(2, 3, figsize=(10, 6))
for i, (idx, row) in enumerate(df.set_index('Business').iterrows()):
ax = axes[i // 3, i % 3]
row = row[row.gt(row.sum() * .01)]
ax.pie(row, labels=row.index, startangle=30)
ax.set_title(idx)
fig.subplots_adjust(wspace=.2)