用法

matplotlib.pyplot.pie(x, explode=None, labels=None, colors=None, autopct=None, pctdistance=0.6, shadow=False, labeldistance=1.1, startangle=0, radius=1, counterclock=True, wedgeprops=None, textprops=None, center=(0, 0), frame=False, rotatelabels=False, *, normalize=True, data=None)

参数介绍

参数
x 楔形尺寸
explode 类似数组,默认值: 无,如果不是无,则是一个len(x)数组,用于指定偏移每个楔块的半径
labels 标签列表:默认值:无,为每个楔块提供标签的一系列字符串
colors 颜色,默认值:无,饼图循环使用的一系列颜色,如果没有,将使用当前活动周期中的颜色
autopct 默认值:无,如果不是无,则是一个字符串或函数,用于用数字值标记楔块.标签将放在楔子内,如果是格式字符串,则标签为fmt%pct,如果是函数,则调用
pctdistance 默认值为0.6,每个饼图切片的中心与生成的文本开头之间的比率
shadow 默认值为:False,楔块的阴影
labeldistance 默认值1.1,绘制饼图标签径向距离,如果设置为’无’,则不会绘制标签,会存储标签以供在图列()中使用
startangle 饼图角度起始角度
radius 默认值1,饼图的半径,数值越大,饼图越大
counterclock 设置饼图的方向,默认值为True,表示逆时针方向,False,为顺时针
wedgeprops 默认值:无,传递给楔形对象的参数,设置楔形的属性
textprops 设置文本对象的字典参数
center 浮点类型的列表,可选参数,图标中心位置
frame 是否选择轴框架,默认值为False,如果是True,则绘制带有表的轴框架
rotatelabels 默认值为False,布尔类型,如果为True,则将每个标签旋转到相应切片的角度
narmalize 布尔类型,默认值为True,如果为True,则始终通过规范化x来制作完整的饼图,使总和(x)=1。如果sum(x)<=1,False将生成部分饼图,并为sum(x)>1引发ValueError。
data 可选参数,如果给定,一下参数接受字符串s,该字符串被解释为数据[s]
案例
x
import numpy as np
import maplotlib.pyplot as pltx = [1, 2, 3, 4]
plt.pie(x)
plt.show()


explode

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [1, 2, 3, 4]plt.subplot(121)
plt.title('正常')
plt.pie(x)plt.subplot(122)
plt.title('添加explode')
plt.pie(x,explode=[0.1,0.2,0.1,0.2])
plt.show()


labels,labeldistance

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(131)
plt.title('正常')
plt.pie(x)plt.subplot(132)
plt.title('添加labels')
plt.pie(x,labels=['x1','y1','x2','y2'])# labeldistance默认为是1.1
plt.subplot(133)
plt.title('添加labels和labeldistance')
plt.pie(x,labels=['x1','y1','x2','y2'],labeldistance=1.2)
plt.show()

colors

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [1, 2, 3, 4]plt.subplot(121)
plt.title('正常')
plt.pie(x)# 颜色参数必须保持和x长度一样
plt.subplot(122)
colors = plt.get_cmap('Blues')(np.linspace(0.2,0.7,len(x)))
print(colors)
plt.title('添加colors')
plt.pie(x,colors=colors)
plt.show()


autopct

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [1, 2, 3, 4]plt.subplot(131)
plt.title('正常')
plt.pie(x)plt.subplot(132)
plt.title('添加autopct为1.1f')
plt.pie(x,autopct='%1.1f%%')plt.subplot(133)
plt.title('添加autopct为10.1f')
plt.pie(x,autopct='%10.1f%%')
plt.show()


pctdistance

import numpy as np
import matplotlib.pyplot as pltplt.figsize=((10,8))
plt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [1, 2, 3, 4]plt.subplot(131)
plt.title('正常')
plt.pie(x)plt.subplot(132)
plt.title('添加pctdistance默认值0.6')
plt.pie(x,autopct='%1.1f%%',pctdistance=0.6)plt.subplot(133)
plt.title('添加pctdistance值1.5')
plt.pie(x,autopct='%1.1f%%',pctdistance=0.8)
plt.show()


pctdistance和autopct设置都可以偏移百分比,一个是同方向偏移,一个是距中心点位置

shadow

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(121)
plt.title('正常')
plt.pie(x)plt.subplot(122)
plt.title('添加shadow')
plt.pie(x,explode=(0,0,0.1,0),shadow=True)plt.show()


startangle

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(121)
plt.title('正常')
plt.pie(x,autopct='%1.1f%%')# 起始角度设置
plt.subplot(122)
plt.title('设置startangle=90')
plt.pie(x,autopct='%1.1f%%',startangle=90)plt.show()


radius

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(121)
plt.title('正常')
plt.pie(x,autopct='%1.1f%%')plt.subplot(122)
plt.title('设置radius=0.9')
plt.pie(x,autopct='%1.1f%%',radius=0.9)plt.show()


counterclock
counterclock=False,设置饼图方向为逆方向

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(121)
plt.title('正常')
plt.pie(x,autopct='%1.1f%%')plt.subplot(122)
plt.title('设置counterclock=False')
plt.pie(x,autopct='%1.1f%%',counterclock=False)plt.show()


wedgeprops
设置楔形的属性
wedgeprops传入字典类型,width设置,可以转变为环形图,edgecolor设置其环形边缘颜色

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(121)
plt.title('正常')
plt.pie(x,autopct='%1.1f%%')plt.subplot(122)
plt.title('设置wedgeprops楔形的属性')
plt.pie(x,autopct='%1.1f%%',wedgeprops=dict(width=0.3, edgecolor='blue'))plt.show()


textprops,center,frame

import numpy as np
import matplotlib.pyplot as pltplt.rcParams['font.family'] = 'SimHei'
plt.rcParams['axes.unicode_minus']=False
x = [15, 30, 45, 10]plt.subplot(131)
plt.title('正常')
plt.pie(x,autopct='%1.1f%%')plt.subplot(132)
plt.title('设置textprops,center=1.1,frame')
plt.pie(x,autopct='%1.1f%%',textprops={'size': 'larger'},center=(1,1),frame=True)plt.subplot(133)
plt.title('设置textprops,center=2.2,frame')
plt.pie(x,autopct='%1.1f%%',textprops={'size': 'x-large'},center=(2,2),frame=True)plt.show()


rotatelabels,normalize
这里不多介绍,可根据上述自己检验,很少被用到

举例
案例来源matplolib官方网站
案例地址
1.取饼图一部分楔形,添加colorbar

import matplotlib.pyplot as plt
from matplotlib.patches import ConnectionPatch
import numpy as npfig, (ax1, ax2) = plt.subplots(1, 2, figsize=(9, 5))
fig.subplots_adjust(wspace=0)ratios = [.27, .56, .17]
labels = ['Approve', 'Disapprove', 'Undecided']
explode = [0.1, 0, 0]
angle = -180 * ratios[0]
ax1.pie(ratios, autopct='%1.1f%%', startangle=angle,labels=labels, explode=explode)xpos = 0
bottom = 0
ratios = [.33, .54, .07, .06]
width = .2
colors = [[.1, .3, .5], [.1, .3, .3], [.1, .3, .7], [.1, .3, .9]]for j in range(len(ratios)):height = ratios[j]ax2.bar(xpos, height, width, bottom=bottom, color=colors[j])ypos = bottom + ax2.patches[j].get_height() / 2bottom += heightax2.text(xpos, ypos, "%d%%" % (ax2.patches[j].get_height() * 100),ha='center')ax2.set_title('Age of approvers')
ax2.legend(('50-65', 'Over 65', '35-49', 'Under 35'))
ax2.axis('off')
ax2.set_xlim(- 2.5 * width, 2.5 * width)theta1, theta2 = ax1.patches[0].theta1, ax1.patches[0].theta2
center, r = ax1.patches[0].center, ax1.patches[0].r
bar_height = sum([item.get_height() for item in ax2.patches])# draw top connecting line
x = r * np.cos(np.pi / 180 * theta2) + center[0]
y = r * np.sin(np.pi / 180 * theta2) + center[1]
con = ConnectionPatch(xyA=(-width / 2, bar_height), coordsA=ax2.transData,xyB=(x, y), coordsB=ax1.transData)
con.set_color([0, 0, 0])
con.set_linewidth(4)
ax2.add_artist(con)# draw bottom connecting line
x = r * np.cos(np.pi / 180 * theta1) + center[0]
y = r * np.sin(np.pi / 180 * theta1) + center[1]
con = ConnectionPatch(xyA=(-width / 2, 0), coordsA=ax2.transData,xyB=(x, y), coordsB=ax1.transData)
con.set_color([0, 0, 0])
ax2.add_artist(con)
con.set_linewidth(4)plt.show()


2.环形图

import numpy as np
import matplotlib.pyplot as plt
fig, ax = plt.subplots()size = 0.3
vals = np.array([[60., 32.], [37., 40.], [29., 10.]])cmap = plt.cm.Set1
outer_colors = cmap(np.arange(3)*4)
inner_colors = cmap([1, 2, 5, 6, 9, 10])ax.pie(vals.sum(axis=1), radius=1, colors=outer_colors,wedgeprops=dict(width=size, edgecolor='w'))ax.pie(vals.flatten(), radius=1-size, colors=inner_colors,wedgeprops=dict(width=size, edgecolor='w'))ax.set(aspect="equal", title='Pie plot with `ax.pie`')
plt.show()

python绘制饼图相关推荐

  1. python绘制饼图双层_Python入门进阶:Python绘制饼图到Microsoft Excel

    原标题:Python入门进阶:Python绘制饼图到Microsoft Excel 来自:Linux迷https://www.linuxmi.com/python-pie-chart-microsof ...

  2. 怎么用python画饼状图_Python入门进阶:Python绘制饼图到Microsoft Excel

    原标题:Python入门进阶:Python绘制饼图到Microsoft Excel 来自:Linux迷https://www.linuxmi.com/python-pie-chart-microsof ...

  3. python读取excel画出饼状图_Python入门进阶:Python绘制饼图到Microsoft Excel

    原标题:Python入门进阶:Python绘制饼图到Microsoft Excel 来自:Linux迷https://www.linuxmi.com/python-pie-chart-microsof ...

  4. python绘制饼图的子图_Python入门进阶:Python绘制饼图到Microsoft Excel

    原标题:Python入门进阶:Python绘制饼图到Microsoft Excel 来自:Linux迷https://www.linuxmi.com/python-pie-chart-microsof ...

  5. python绘制饼图-Python使用Plotly绘图工具,绘制饼图

    今天我们来学习一下如何使用Python的Plotly绘图工具,绘制饼图 使用Plotly绘制饼图的方法,我们需要使用graph_objs中的Pie函数 函数中最常用的两个属性values,用于赋值给需 ...

  6. python polar函数_Python可视化很简单,可是你会吗?python绘制饼图、极线图和气泡图,让我来教教你吧,一文教会!!!...

    matplotlib库作为Python数据化可视化的最经典和最常用库,掌握了它就相当于学会了Python的数据化可视化,今天呢,咱们就一起来聊聊关于Python如何去绘制饼图.极线图和气泡图吧 好啦, ...

  7. python绘制饼图的如何设置高度宽度_python 用 matplotlib 饼图参数详解 plt.pie()

    defax_set_title(s): ax.set_title(label=f'No.{i+1}\n'+s, #标题的文本内容 loc='right', #标题的位置 family='Arial', ...

  8. python 绘制饼图

    饼图反映了数据的占比,各个数据的占比由系统自动计算. labels=['asda','aaa','bbb'] plt.figure(figsize=(6,4))#设置画布\n", plt.p ...

  9. python绘制饼图双层_有趣!如何用Python-matplotlib绘制双层饼图及环形图?

    (1) 饼图(pie),即在一个圆圈内分成几块,显示不同数据系列的占比大小,这也是我们在日常数据的图形展示中最常用的图形之一. 在python中常用matplotlib的pie来绘制,基本命令如下所示 ...

最新文章

  1. 嵌入式Linux开发环境的搭建
  2. 在Windows系统中安装WAMP
  3. ITK:通过包装填充图像
  4. hdu4821 字符串hash(有多少(M*L长的,M个不相同)子串))
  5. vue数组操作不更新视图问题
  6. 我改了500个Bug,但是!!
  7. Valgrind快速入门指南
  8. Redis之List类型操作
  9. 奖金福利高达20亿,华为太太太太太任性了!
  10. 用免费WiFi 连接消费者,Zenreach 获 3000 万美元B轮融
  11. Modern CMake 翻译 2.1 变量和缓存
  12. 关于Microsoft Enterprise Library的介绍
  13. 关于linux下anaconda的pip包及其他包的本地更新方法
  14. OpenCV的第一个小程序:读取图像并显示
  15. hcia第五天 结课
  16. 浏览器的UserAgent
  17. STM32采用串口DMA方式,发送数据
  18. 共享打印机连接报错问题汇总
  19. 腾讯企业邮箱 java_java发送腾讯企业邮件-可用于发送邮箱验证码
  20. UnityShader源码2017---学习笔记与自我拓展019

热门文章

  1. Android 实现顶层窗口、悬浮窗口
  2. 沃尔沃升级刷藏功能取消限速180km解除行车播放视频关闭自动启停系统
  3. 悟空浏览器——青龙羊毛
  4. 宏碁暗影骑士AN515-55/57/58原厂预装系统oem镜像
  5. java去除中文括号小括号,或者英文括号
  6. 一叶知秋:通过Incloud Rail感受浪潮超融合架构
  7. obsolete or deprecated parameter(s) specified for RDBMS instanc
  8. 智能设计|零基础,低成本,轻松实现设计效率翻倍
  9. Unity(游戏)中五种数据存储的方法
  10. Python实战技巧(11)使用python收发邮件时需要的邮箱授权码如何获取