Python 如何在matplotlib pyhon中制作甜甜圈饼图的子图

Python 如何在matplotlib pyhon中制作甜甜圈饼图的子图,python,matplotlib,pie-chart,Python,Matplotlib,Pie Chart,如何在matplotlib pyhon的甜甜圈饼图中生成子图 下面是我写的代码 import matplotlib.pyplot as plt labels = 'Frogs', 'Hogs', 'Dogs' sizes = [15, 30, 45] colors = ['yellowgreen', 'gold', 'lightskyblue'] explode = (0, 0, 0) # explode a slice if required subgroup_names = ['A.1'

如何在matplotlib pyhon的甜甜圈饼图中生成子图

下面是我写的代码

import matplotlib.pyplot as plt

labels = 'Frogs', 'Hogs', 'Dogs'
sizes = [15, 30, 45]
colors = ['yellowgreen', 'gold', 'lightskyblue']
explode = (0, 0, 0)  # explode a slice if required
subgroup_names = ['A.1', 'A.2', 'A.3', 'B.1', 'B.2', 'C.1']
subgroup_size = [13, 3, 5, 6, 5, 10]
a, b, c = [plt.cm.Blues, plt.cm.Reds, plt.cm.Greens]

plt.pie(sizes, explode=explode, labels=labels, pctdistance=0.45, labeldistance=0.65, colors=colors, autopct='%.2f%%', shadow=True)
centre_circle = plt.Circle((0, 0), 0.175, color='black', fc='white', linewidth=1.25)

plt.pie(subgroup_size, labels=subgroup_names, pctdistance=0.85, labeldistance=1.25, colors=[a(0.5), a(0.4), a(0.3), b(0.5), b(0.4), c(0.6)], autopct='%.2f%%', shadow=True)
centre_circle2 = plt.Circle((0, 0), 0.275, color='red', fc='white', linewidth=1.25)

fig = plt.gcf()
fig.gca().add_artist(centre_circle)
fig.gca().add_artist(centre_circle2)


plt.axis('equal')
plt.show()
结果如下图所示

但我希望结果如下图所示(必须显示百分比值)。这是我希望得出的结果(百分比值):


Matplotlib文档提供了非常好的示例,几乎可以满足您的所有需求。有关嵌套饼图,请参见

在“仅链接答案”上的注释之后,关键字radius是您在调用pie()时要查找的内容。它接受一个浮动,它决定了饼图的绝对半径。因此,绘制嵌套的pie需要多次调用pie(),每次调用的半径值不同。请参见下面的示例

import matplotlib.pyplot as plt
plt.pie([1, 2, 3], radius=1,
        colors=['xkcd:cerulean', 'xkcd:bright red', 'xkcd:grass green'],
        labels=['Group A', 'Group B', 'Group C'], autopct='%.2f%%',
        pctdistance=0.85, shadow=True,
        wedgeprops=dict(width=0.3, edgecolor='white'))

plt.pie([0.3, 0.7, 0.4, 1.5, 0.1, 3], radius=0.7,
        colors=['xkcd:sky blue', 'xkcd:light blue', 'xkcd:reddish pink',
                'xkcd:salmon pink', 'xkcd:baby pink', 'xkcd:apple green'],
        wedgeprops=dict(width=0.3, edgecolor='white'),
        labels=['A.1', 'A.2', 'B.1', 'B.2', 'B.3', 'C.1'], autopct='%.2f%%',
        pctdistance=0.8, labeldistance=0.4, shadow=True)
plt.axis('equal')
plt.show()
返回下面的图

中有一个嵌套图表的示例。你能在这里应用它,然后问剩下的问题吗?