加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 饼图标签重叠相同的值.

发布时间:2020-12-20 11:34:56 所属栏目:Python 来源:网络整理
导读:在这里,我正在尝试使用matplotlib python库创建一个饼图.但如果值多次相同“0.0”,则日期重叠. 我的问题是如何单独显示它们. 谢谢. 这是我试过的: from pylab import *labels = [ "05-02-2014","23-02-2014","07-02-2014","08-02-2014"]values = [0,2,10]fi
在这里,我正在尝试使用matplotlib python库创建一个饼图.但如果值多次相同“0.0”,则日期重叠.
我的问题是如何单独显示它们.

谢谢.

这是我试过的:

from pylab import *

labels = [ "05-02-2014","23-02-2014","07-02-2014","08-02-2014"]
values = [0,2,10]
fig = plt.figure(figsize=(9.0,6.10)) 
plt.pie(values,labels=labels,autopct='%1.1f%%',shadow=True)
plt.axis('equal')
show()

解决方法

您可以手动调整标签位置,但这样可以为这样一个简单的请求提供更多代码.您可以通过检查放置的位置来检测重复标签组.

这是一个示例,其中一些随机数据复制了重叠标签的出现:

import matplotlib.pyplot as plt
import numpy as np
from collections import Counter
import datetime

# number slices of pie
num = 10

# generate some labels
dates = [datetime.datetime(2014,1,1) + datetime.timedelta(days=np.random.randint(1,20)) for i in range(num)]
labels = [d.strftime('%d-%m-%Y') for d in dates]

# generate some values
values = np.random.randint(2,10,num)

# force half of them to be zero
mask = np.random.choice(num,num // 2,replace=False)
values[mask] = 0

# pick some colors
colors = plt.cm.Blues(np.linspace(0,num))

fig,ax = plt.subplots(figsize=(9.0,6.10),subplot_kw={'aspect': 1})
wedges,labels,pcts = ax.pie(values,colors=colors,autopct='%1.1f%%')


# find duplicate labels and the amount of duplicates
c = Counter([l.get_position() for l in labels])
dups = {key: val for key,val in c.items() if val > 1}

# degrees of spacing between duplicate labels
offset = np.deg2rad(3.)


# loop over any duplicate 'position'
for pos,n in dups.items():

    # select all labels with that position
    dup_labels = [l for l in labels if l.get_position() == pos]

    # calculate the angle with respect to the center of the pie
    theta = np.arctan2(pos[1],pos[0])

    # get the offsets
    offsets = np.linspace(-(n-1) * offset,(n-1) * offset,n)

    # loop over the duplicate labels
    for l,off in zip(dup_labels,offsets):

        lbl_radius = 1.3

        # calculate the new label positions
        newx = lbl_radius * np.cos(theta + off)
        newy = lbl_radius * np.sin(theta + off)

        l.set_position((newx,newy))

        # rotate the label
        rot = np.rad2deg(theta + off)

        # adjust the rotation so its
        # never upside-down
        if rot > 90:
            rot += 180
        elif rot < -90:
            rot += 180

        # rotate and highlight the adjusted labels
        l.set_rotation(rot)
        l.set_ha('center')
        l.set_color('#aa0000')

我故意只修改重叠标签以突出显示效果,但您可以以类似的方式更改所有标签以创建统一样式.旋转可以更容易地自动分隔它们,但您可以尝试其他放置方式.

请注意,它只检测真正相同的展示位置,如果您的值为[0,0.00001,10],它们可能仍会重叠.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读