matplotlib中的双圆环图

wko9yo5t  于 2023-08-06  发布在  其他
关注(0)|答案(2)|浏览(103)

好了,matplotlib爱好者们,我们知道如何绘制donut chart,但还有什么比甜甜圈图更好呢?双圆环图具体而言:我们有一组元素,它们属于第一个分类的不相交的类别和子类别。圆环图应该在外圈有类别切片,在内圈有子类别切片,显然与外圈切片对齐。
有没有提供这个的库,或者我们需要在这里解决这个问题?


的数据

nvbavucw

nvbavucw1#

若要获得双圆环图,可以在同一图中绘制任意多个饼图。因此,外部饼图的楔形将设置为width,内部饼图的半径将小于或等于1-width

import matplotlib.pyplot as plt
import numpy as np

fig, ax = plt.subplots()
ax.axis('equal')
width = 0.3

# Outer ring
cm = plt.get_cmap("tab20c")
cout = cm(np.arange(3)*4)
pie, _ = ax.pie([120,77,39], radius=1, labels=list("ABC"), colors=cout)
plt.setp(pie, width=width, edgecolor='white')

# Inner ring
cin = cm(np.array([1,2,5,6,9,10]))
labels = list(map("".join, zip(list("aabbcc"),map(str, [1,2]*3))))
pie2, _ = ax.pie([60,60,37,40,29,10], radius=1-width, labels=labels,
                 labeldistance=0.7, colors=cin)
plt.setp(pie2, width=width, edgecolor='white')
plt.show()

字符串


的数据

3xiyfsfu

3xiyfsfu2#

我改编了你提供的例子;你可以通过在同一图形上绘制两个圆环来解决这个问题,其中一个的外半径较小。

import matplotlib.pyplot as plt
import numpy as np

def make_pie(sizes, text,colors,labels, radius=1):
    col = [[i/255 for i in c] for c in colors]

    plt.axis('equal')
    width = 0.35
    kwargs = dict(colors=col, startangle=180)
    outside, _ = plt.pie(sizes, radius=radius, pctdistance=1-width/2,labels=labels,**kwargs)
    plt.setp( outside, width=width, edgecolor='white')

    kwargs = dict(size=20, fontweight='bold', va='center')
    plt.text(0, 0, text, ha='center', **kwargs)

# Group colors
c1 = (226, 33, 7)
c2 = (60, 121, 189)

# Subgroup colors
d1 = (226, 33, 7)
d2 = (60, 121, 189)
d3 = (25, 25, 25)

make_pie([100, 80, 90], "", [d1, d3, d2], ['M', 'N', 'F'], radius=1.2)
make_pie([180, 90], "", [c1, c2], ['M', 'F'], radius=1)
plt.show()

字符串
x1c 0d1x的数据

相关问题