matplotlib使用subplot2grid() 函数将整个画布划成非等分布局的区域

# matplotlib中文网 https://www.matplotlib.org

subplot()函数

使用pyplot的subplot()函数可以在规划好的某个区域中绘制单个子图,subplot()函数的语法格式如下:

subplot(nrows,ncols,inddex,projection,polar,sharex,sharey,label,**kwargs)

该函数的常用参数含义如下:

  • nrows:表示规划区域的行数。
  • ncols:表示规划区域的列数
  • index:表示选择区域的索引,默认从1开始编号。
  • projection:表示子图的投影类型,可以为None、‘aitoff’、‘hammer’、‘lambert’、‘mollweide’、‘polar’、‘rectilinear’中任一取值,其中默认值为None代表使用‘rectilinear’直线投影。
  • polar:表示是否使用极坐标,默认值为False。若参数polar设为True,则作为等同于projection=‘polar’
  • sharex,sharey:表示是否共享子图的x轴或y轴

subplot2grid()函数 

使用pyplot的subplot2grid()函数可以将整个画布规划成非等分布局的区域,并可在选中的某个区域中绘制单个子图,subplot2grid()函数的语法格式如下:

subplot2grid(shape,loc,rowspan=1,colspan=1,fig=None,**kwargs)

该函数常用参数的含义如下:

  • shape:表示规划的区域结构,它是一个包含两个整型数据的元组,其中第一个元素表示规划区域的行数,第二个函数表示规划区域的列数。
  • loc:表示选择区域的位置,它是一个包含两个整型数据的元组,其中第一个元素表示子图所在的行数(行数从0开始),第二个元素表示子图所在的列数(列数从0开始)。
  • rowspan:表示向下跨越的行数,默认为1。
  • colspan:表示向右跨越的列数,默认为1。
  • fig:表示放置子图的画布,默认为当前画布。

运行代码如下

# 导入模块
import numpy as np
import matplotlib.pyplot as plt

# 设置中文
plt.rcParams['font.sans-serif'] = ["SimHei"]

# 导入数据
x = [x for x in range(1, 13)]
y1 = [20, 28, 23, 16, 29, 36, 39, 33, 31, 19, 21, 25]
y2 = [17, 22, 39, 26, 35, 23, 25, 27, 29, 38, 28, 20]
labels = ['1 月', '2 月', '3 月', '4 月', '5 月', '6 月', '7月', '8 月', '9 月', '10 月', '11 月', '12 月']

# 绘制第一个子图
ax1 = plt.subplot2grid((2, 4), (0, 1), colspan = 2)
# 画布被规划成 2 X 4 的矩阵区域,之后在第0行第1列的区域中绘制一个向右跨越2列的子图
ax1.plot(x, y1, 'm--o', lw=2, ms=5, label='产品A')
ax1.plot(x, y2, 'g--o', lw=2, ms=5, label='产品B')
ax1.set_title("产品A 与产品B的销售额", fontsize=11)
ax1.set_ylim(10, 45)
ax1.set_ylabel('销售额(亿元)')
ax1.set_xlabel('月份')
for xy1 in zip(x, y1):
    ax1.annotate("%s" % xy1[1], xy=xy1, xytext=(-5, 5), textcoords='offset points')
for xy2 in zip(x, y2):
    ax1.annotate("%s" % xy2[1], xy=xy2, xytext=(-5, 5), textcoords='offset points')
ax1.legend()

# 绘制第二个子图
ax2 = plt.subplot2grid((2, 4), (1, 0))
# 画布被规划成 2 X 4 的矩阵区域,之后在第1行第0列的区域中绘制子图
ax2.pie(y1, radius=1, wedgeprops={'width':0.5}, labels=labels, autopct='%3.1f%%', pctdistance=0.75)
ax2.set_title('产品A的销售额 ')

# 绘制第三个子图
ax3 = plt.subplot2grid((2, 4), (1, 3))
# 画布被规划成 2 X 4 的矩阵区域,之后在第1行第3列的区域中绘制子图
ax3.pie(y2, radius=1, wedgeprops={'width':0.5}, labels=labels,autopct='%3.1f%%', pctdistance=0.75)
ax3.set_title('产品B的销售额 ')

# 调整子图之间的距离
plt.tight_layout()
plt.show()

运行结果展示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值