赞
踩
Matplotlib在一张画布上画多个图的两种方法,plt.subplot,plt.subplots。
之前也用过plt.subplots()在一张图上画过多个图,今天看到用plt.subplot()的画法想着也来实现下,同时也发现了两者之间的优缺点,感觉subplot()更便捷一点。其实两者都是别人写好的库函数,只要理解好库函数的传递参数的参数,合理的将自己传入的参数整理,两者都容易上手的。
这里我用的是jupyter notebook 画的,工具挺多的。
import matplotlib.pyplot as plt import numpy as np #数据 v1 = [5, 20, 36, 10, 75, 90] v2 = [10, 25, 8, 60, 20, 80] attr = ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"] #plt.subplots()是一个函数,返回一个包含figure和axes数组对象的元组 figure ,axes =plt.subplots(2,2,figsize=(18,12),dpi=100) # 设置显示中文 plt.rcParams['font.sans-serif'] = ['SimHei'] # 指定默认字体 plt.rcParams['axes.unicode_minus']=False # 正常显示负号 ax = axes.flatten() #子图展平,将ax由n*m的Axes组展平成1*nm的Axes组(二维变一维) # 绘制直方图 # data:必选参数,绘图数据 # bins:直方图的长条形数目,可选项,默认为10 # facecolor:长条形的颜色 # edgecolor:长条形边框的颜色 data = np.random.randn(1000)# 随机生成(1000)服从正态分布的数据 axes[0][0].hist(data,bins=30,facecolor='blue',edgecolor='red') axes[0][0].set_xlabel("区间")# 显示横轴标签 axes[0][0].set_ylabel("频数/频率")# 显示纵轴标签 axes[0][0].set_title("hist") # 绘制条形图 axes[0][1].bar(attr,v1,width=0.4, alpha=0.8, color='red', label="v1") # axes[0][1].bar(attr,v2,width=0.3, alpha=0.8, color='green', label="v2") axes[0][1].set_title("bar") axes[0][1].set_xlabel("类别")# 显示横轴标签 axes[0][1].set_ylabel("销量")# 显示纵轴标签 axes[0][1].legend() # 绘制条形图 ax[2].bar(attr,v2,width=0.4, alpha=0.8, color='green', label="v1") # axes[0][1].bar(attr,v2,width=0.3, alpha=0.8, color='green', label="v2") ax[2].set_title("bar1") ax[2].set_xlabel("类别")# 显示横轴标签 ax[2].set_ylabel("销量")# 显示纵轴标签 ax[2].legend() # 绘制饼图 sum =0 for data in v2: sum+=data d =[] for data in v2: d.append(data/sum) explode = [0.06,0,0,0,0.05,0] ax[3].pie(x=d,labels=attr,autopct = '%3.2f%%', colors=('b', 'g', 'r', 'c', 'm', 'y'),explode=explode) ax[3].set_title("pie") ax[3].axis('equal') ax[3].legend() # x (每一块)的比例,如果sum(x) > 1会使用sum(x)归一化 # labels (每一块)饼图外侧显示的说明文字 # explode (每一块)离开中心距离 # startangle 起始绘制角度,默认图是从x轴正方向逆时针画起,如设定=90则从y轴正方向画起 # shadow 是否阴影 # labeldistance label绘制位置,相对于半径的比例, 如<1则绘制在饼图内侧 # autopct 控制饼图内百分比设置,圆里面的文本格式,%3.1f%%表示小数有三位,整数有一位的浮点数 # pctdistance 类似于labeldistance,指定autopct的位置刻度 # radius 控制饼图半径 plt.savefig("D:\\StudyDemo\\IDEA\\PythonDemo\\MatplotlibPaint\\SaveData\\subplots.png") plt.show()
图subplots
import matplotlib.pyplot as plt import numpy as np #数据 v1 = [5, 20, 36, 10, 75, 90] v2 = [10, 25, 8, 60, 20, 80] attr = ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"] # 设置显示中文 plt.rcParams['font.sans-serif'] = ['SimHei'] # 指定默认字体 plt.rcParams['axes.unicode_minus']=False # 正常显示负号 #设置画布大小像素点 plt.figure(figsize=(14,14),dpi=100) # 绘制直方图 plt.subplot(2,2,1) data = np.random.randn(1000)# 随机生成(1000)服从正态分布的数据 plt.hist(data,bins=40,facecolor='blue',edgecolor='red') plt.ylabel("频率/区间") plt.xlabel("区间") plt.title("直方图") # 绘制条形图 plt.subplot(2,2,2) plt.bar(attr,v1,width=0.4, alpha=0.8, color='red', label="v1") plt.legend() plt.ylabel("销量") plt.xlabel("种类") plt.title("条形图") # 绘制条形图 plt.subplot(2,2,3) plt.bar(attr,v2,width=0.4, alpha=0.8, color='black', label="v2") plt.legend() plt.ylabel("销量") plt.xlabel("种类") plt.title("条形图") # 绘制条形图 plt.subplot(2,2,4) sum =0 for data in v2: sum+=data d =[] for data in v2: d.append(data/sum) explode = [0.06,0,0,0,0.05,0] plt.pie(x=d,explode=explode,labels=attr,autopct = '%3.2f%%', colors=('b', 'g', 'r', 'c', 'm', 'y')) plt.legend() plt.title("饼图") plt.savefig("D:\\StudyDemo\\IDEA\\PythonDemo\\MatplotlibPaint\\SaveData\\subplot.png") plt.show()
图subplot
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。