数据分析与展示 Matplotlib库入门

Matplotlib库入门

说明:Matplotlib库由各种可视化类构成,内部结构复杂,受Matlab启发matplotlib.pyplot是绘制各类可视化图形的命令子库,相当于快捷方式 improt matplotlib.pyplot as plt

matplotlib小测

例1: matplotlib小测
import matplotlib.pylab as plt

# plt.plot()只有一个输入或数组时,参数被当作y轴,x轴以索引自动生成;
# plt.plot(x,y)当两个以上参数时,按照x轴和y轴顺序绘制数据点
# plt.plot([3,1,4,5,2])
plt.plot([0,2,4,6,8],[3,1,4,5,2])
# plt.ylabel() 设置Y轴标签
plt.ylabel("Grade")
# plt.savefig()将输出图形存储为文件,默认为PNG文件,通过dpi修改输出质量
plt.savefig('test1',dpi=600)
# 显示
plt.show()

pyplot的绘图区域

plt.subplot(nrows, ncols, plot_number)

例2 pyplot的绘图区域
import matplotlib.pylab as plt
import numpy as np

# plt.subplot(nrows, ncols, plot_number)
# plt.subplot(111)
# plt.subplot(211)
# plt.subplot(321)
# plt.subplot(322)
# plt.subplot(323)
# plt.subplot(324)
# plt.subplot(325)
# plt.subplot(326)
# plt.show()

# def f(t):
#     return np.exp(-t) * np.cos(2*np.pi*t)
#
# a = np.arange(0.0,5.0,0.02)
#
# # pyplot的绘图区域
# plt.subplot(211)
# plt.plot(a,f(a))
#
# plt.subplot(212)
# plt.plot(a, np.cos(2*np.pi*a),'r--')
#
# # plt.plot() 更多参数例子
# plt.plot(a,f(a),a,np.cos(2*np.pi*a),'r--')
# plt.show()

# plt.plot(x, y, format_string, **kwargs)
 X: x轴数据,列表或数组,可选
 Y: y轴数据,列表或数组
 format_string: 控制曲线的格式字符串,可选
 **kwargs      :第二组或更多(x,y,format_string)

注意:当绘制多条曲线时,各条曲线的x不能省略

format_string:控制曲线的格式字符串,可选 由颜色字符、风格字符和标记字符组成

颜色字符说明颜色字符说明
‘b’蓝色‘m’洋红色 magenta
‘g’绿色‘y’黄色
‘r’红色‘k’黑色
‘c’青绿色 cyan‘w’白色
‘#008000’RGB某颜色‘0.8’灰度值字符串
风格字符说明
‘-’实线
‘–’破折线
‘-.’点划线
‘:’虚线
‘’ ’ ’无线条

format_string:控制曲线的格式字符串,可选

标记字符说明标记字符说明标记字符说明
‘.’点标记‘1’下花三角标记‘h’竖六边形标记
‘,’像素标记(极小点)‘2’上花三角标记‘H’横六边形标记
‘o’实心圈标记‘3’左花三角标记‘+’十字标记
‘v’倒三角标记‘4’右花三角标记‘x’x标记
‘^’上三角标记‘s’实心方形标记‘D’菱形标记
‘>’右三角标记‘p’实心五角标记‘d’瘦菱形标记
‘<’左三角标记‘*’星形标记
 plt.plot(x, y, format_string, **kwargs)
 **kwargs	:第二组或更多(x,y,format_string)
 color		:控制颜色。color='green'
 linestyle	:线条风格。linestyle='dashed'
 marker		:标记风格。marker='o'
 markerfacecolor:标记颜色,markerfacecolor='blue'
 markersize	:标记尺寸,markersize=20

pyplot的中文显示

pyplot的中文显示:第一种

pyplot并不默认支持中文显示,需要rcParams修改字体实现
# 例3
import matplotlib.pyplot as plt
import matplotlib

# pyplot并不默认支持中文显示,需要rcParams修改字体实现.SimHei是黑体
matplotlib.rcParams['font.family']='SimHei'
plt.plot([3, 1, 4, 5, 2])
plt.ylabel("纵轴(值)")
# plt.savefig('test',dpi=600)
plt.show()

rcParams的属性

属性说明
‘font.family’用于显示字体名称
‘font.style’字体风格,正常’normal’或 斜体’italic’
‘font.size’字体大小,整数字号或者’large’、‘x-small’

中文字体的种类

中文字体说明
‘SimHei’中文黑体
‘Kaiti’中文楷体
‘LiSu’中文隶书
‘FangSong’中文仿宋
‘YouYuan’中文幼圆
‘STSong’华文宋体
# 例3.1
 import numpy as np
 import matplotlib.pyplot as plt
 import matplotlib
 
 matplotlib.rcParams['font.family']='STSong'
 matplotlib.rcParams['font.size']=20
 a = np.arange(0.0,5.0,0.02)
 plt.subplot(111)
 plt.xlabel('横轴:时间')
 plt.ylabel('纵轴:振幅')
 plt.plot(a,np.cos(2*np.pi*a),'r--')
 plt.show()

pyplot的中文显示:第二种

在有中文输出的地方,增加一个属性:fontproperties
例3.2
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0, 5.0, 0.02)
plt.xlabel('横轴:时间',fontproperties='SimHei',fontsize=20)
plt.ylabel('纵轴: 振幅',fontproperties='SimHei',fontsize=20)
plt.plot(a,np.cos(2*np.pi*a),'r-.')
plt.show()

pyplot的文本显示

pyplot的文本显示函数

plt.xlabel():对X轴增加文本标签
plt.ylabel():对Y轴增加文本标签
plt.title():对图形整体增加文本标签
plt.text():在任意位置增加文本
plt.annotate():在图形中增加带箭头的注解

# 实例4.0
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0,5.0,0.02)
plt.plot(a,np.cos(2*np.pi*a),'r--')
plt.xlabel('横轴:时间',fontproperties='SimHei',fontsize=15,color='green')
plt.ylabel('纵轴:振幅',fontproperties='SimHei',fontsize=15,color='red')
plt.title('正弦波实例 $y=cos(2\pi x)$',fontproperties='Kaiti',fontsize='25')
plt.text(2,1,'$\mu=100$',fontsize=15)

# matplotlib.pyplot.axis(*args, emit=True, **kwargs)
# xmin,xmax,ymin,ymax 浮动,可选
# https://matplotlib.org/api/_as_gen/matplotlib.pyplot.axis.html
plt.axis([-1,6,-2,2])
plt.grid(True)
plt.show()

# plt.annotate(s,xy=arrow_crd, xytext=text_crd, arrowprops=dict)
# 实例4.1
import numpy as np
import matplotlib.pyplot as plt

a = np.arange(0.0,5.0,0.02)
plt.plot(a, np.cos(2*np.pi*a),'r--')
plt.xlabel('横轴:时间', fontproperties='Kaiti',fontsize=15,color='green')
plt.ylabel('纵轴:振幅',fontproperties='Kaiti',fontsize=15,color='red')
plt.title('正弦波实例 $y=cos(2\pi x)$',fontproperties='Kaiti')
plt.annotate('$\mu=100$',xy=(2,1),xytext=(3,1.2),
			 arrowprops=dict(facecolor='black',shrink=0.1,width=2))
plt.axis([-1,6,-2,2])
plt.grid(True)
plt.show()

pyplot的子绘图区域

plt.subplot2grid()

plt.subplot2grid(GridSpec, CurSpec, colspan=1, rowspan=1)
理念:设定网格,选网格,确定选中行列区域数量,编码从0开始
# 实例5.0
# subplot2grid(shape, loc, rowspan=1, colspan=1, fig=None, **kwargs)
import matplotlib.pyplot as plt

plt.subplot2grid((3,3),(0,0),colspan=3)
plt.subplot2grid((3,3),(1,0),colspan=2)
plt.subplot2grid((3,3),(1,2),rowspan=2)
plt.subplot2grid((3,3),(2,0))
plt.subplot2grid((3,3),(2,1))
plt.show()

GridSpec类

# 实例5.1 GridSpec类
import matplotlib.pyplot as plt
import matplotlib.gridspec as gridspec

gs = gridspec.GridSpec(3,3)
ax1 = plt.subplot(gs[0,:])
ax2 = plt.subplot(gs[1,:-1])
ax3 = plt.subplot(gs[1:,-1])
ax4 = plt.subplot(gs[2,0])
ax5 = plt.subplot(gs[2,1])
plt.show()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值