一、matplotlib的介绍

1、matplotlib是提供数据绘图功能的第三方库,其pyplot子库主要用于实现各种数据展示图形的绘制。

2、pyplot子库的引用方式如下:

import matplotlib.pyplot as plt

3、为了正确显示中文字体,请用一下代码更改默认设置,其中“SimHei”表示黑体字

>>>import matplotlib

>>>matplotlib.rcParams['font.family']='SimHei'

>>>matplotlib.rcParams['font.sans-serif']=['SimHei']

二、matplotlib.pyplot库解析

1、plt子库提供了一批操作和绘图函数,每个函数代表对图像进行的一个操作,比如创建绘图区域、添加标注或者修改坐标轴等。

2、这些函数采用plt.<b>()形式调用,其中<b>是具体函数名称

3、plt库的绘图区域函数

函数

说明

plt.figure(figsize=None,facecolor=None)

创建一个全局绘图区域,figsize参数可以指定绘图区域的宽度和高度

plt.axes(rect,axisbg='w')

创建一个坐标系风格的子绘图区域,参数表示将全局绘图区域分成nrows行和ncols列,并根据先行后列的计数方式在plot_number位置上生成一个坐标系

plt.subplot(nrows,ncols,plot_number)

在全局绘图区域中创建一个子绘图区域

plt.subplots_adjust()

调整子图区域的布局

 

 

 

 

 

 

 

 

 

注意:axes()默认创建一个subplot(111)坐标系,参数rec=[left,bottom,width,height]中四个变量的范围都为[0,1],表示坐标系与全局绘图区域的关系;axisbg指背景色,默认为white

 

4、plt库的读取和显示函数

 

函数

说明

plt.legend()

在绘图区域中方式绘图标签(也称图注)

plt.show()

显示创建的绘图对象

plt.matshow()

在窗口显示数组矩阵

plt.imshow()

在axes上显示图像

plt.imsave()

保存数组为图像文件

plt.imread()

从图像文件中读取数组

 

 

 

 

 

 

 

 

 

 

5、plt库的基础表函数

 

操作

说明

plt.plot(x,y,lable,color,width)

根据x,y数组绘制直/曲线,x和y可以是numpy计算出的数组,label表示设置标签并在图例中显示,color表示曲线的颜色,width表示曲线的宽度

plt.boxplot(data,notch,position)

绘制一个箱型图(Box-plot)

plt.bar(left,height,width,bottom)

绘制一个条形图

plt.barh(bottom,width,height,left)

绘制一个横向条形图

 

 

 

 

 

 

plt.polar(theta,r)

绘制极坐标图

plt.pie(data,explode)

绘制饼图

plt.psd(x,NFFT=256,pad_to,Fs)

绘制功率谱密度图

plt.specgram(x,NFFT=256,pad_to,F)

绘制谱图

plt.cohere(x,y,NEET=256,Fs)

绘制X-Y的相关性函数

plt.scatter()

绘制散点图(x,y是长度相同的序列)

plt.step(x,y,where)

绘制步阶图

plt.hist(x,bins,normed)

绘制直方图

plt.contour(X,Y,Z,N)

绘制等值线

plt.vlines()

绘制垂直线

plt.stem(x,y,linefmt,markerfmt,basefmt)

绘制曲线每个点到水平轴线的垂线

plt.plot_data()

绘制数据日期

plt.plotfile()

绘制数据后写入文件

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

例如:绘制一个简单图形

a、当plt.plot()中输入参数只有一个列表或数组时,此参数会被当做y轴处理,x轴是此列表的索引(自动生成)

 

 

雷达图函数python 雷达图函数名_Python

 

雷达图函数python 雷达图函数名_Python_02

 

b、当plt.plot()有两个以上参数时,分别对应x轴和y轴绘制图像,可使用axis()函数设置横纵坐标尺度的函数(设置X,Y坐标的起点和终点)

 

雷达图函数python 雷达图函数名_雷达图函数python_03

 

 

雷达图函数python 雷达图函数名_数据_04

 

 

三、绘制雷达图

代码

1 import numpy as np
 2 import matplotlib 
 3 import matplotlib.pyplot as plt
 4 matplotlib.rcParams['font.family']='SimHei'
 5 matplotlib.rcParams['font.sans-serif']=['SimHei']
 6 labels=np.array(['第一周','第二周','第三周','第四周','第五周','第六周'])
 7 nAttr=6
 8 Python=np.array([60.4,57.9,100,100,92.4,87.5])
 9 angles=np.linspace(0,2*np.pi,nAttr,endpoint=False)
10 Python=np.concatenate((Python,[Python[0]]))
11 angles=np.concatenate((angles,[angles[0]]))
12 fig=plt.figure(facecolor="white")
13 plt.subplot(111,polar=True)
14 plt.plot(angles,Python,'bo-',color='g',linewidth=2)
15 plt.fill(angles,Python,facecolor='g',alpha=0.2)
16 plt.thetagrids(angles*180/np.pi,labels)
17 plt.figtext(0.52,0.95,'Rachel的python成绩分析图',ha='left')
18 plt.figtext(0.52,0.95,'2019310143011',ha='right')
19 plt.grid(True)
20 plt.savefig('acculate.JPG')
21 plt.show()

结果

雷达图函数python 雷达图函数名_数组_05

 

四、绘制数学函数

r=3*(1+cos(a))

代码如下

1 import numpy as np 
2 import matplotlib.pyplot as plt
3 plt.axis([-1,9,-4,4])
4 a=np.linspace(0,2*np.pi,1000)
5 r=3*(1+np.cos(a))
6 x=r*np.cos(a)
7 y=r*np.sin(a)
8 plt.plot(x,y,'x',linewidth=2)

结果如下

雷达图函数python 雷达图函数名_雷达图函数python_06