Matplotlib可视化教程:Matplotlib的使用

Matplotlib绘图样式

线条属性

  • color颜色
  • linewith宽度
  • linestyle样式
  • alpha透明度
  • marker标记
  • mfc:make face color 标记的背景颜色
python 复制代码
import matplotlib.pyplot as plt

fig = plt.figure()
ax1 = plt.subplot(111)
ax2 = ax1.twinx()

ax1.set_xlabel("Distance")
ax1.set_ylabel("Density")
ax2.set_ylabel("Temperature")

ax1.plot([0, 1, 2], [0, 1, 2], 

label="Density",color='red',marker='o',linestyle='solid',mfc='b',markersize=10,markeredgecolor='g',markeredgewidth=1,)

ax2.plot([0, 1, 2], [10, 13, 12], label="Temperature",c='b',marker='v',alpha=0.3,)

fig.legend()

Matplotlib设置坐标轴

​ 图表坐标轴是用来显示和表示数据的数值在图表中的位置的线性轴线。坐标轴有两个方向:水平轴(X轴)和垂直轴(Y轴)

单轴设置X与Y轴刻度

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

#1:准备数据
# 1天的温度
data = [-4,-2,-1,0,1,2,-3,5,3,1]
#时间
x = range(1,11)
#绘制图像
plt.plot(x,data)

# x轴刻度
x_ticks = [f'{i}点' for i in range(1,len(data))]
#设置X轴刻度
plt.xticks(x_ticks)
#设置Y轴刻度
y_ticks = range(min(data),max(data)+1)
plt.yticks(y_ticks)
plt.show()

双轴设置y轴刻度

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

#方法一
#   1;准备数据
#  1天24小时的温度
data1 = [-5,1,5,2,6,8,11,13,12,10,9,4,6,4,3,2]
#  1天24小时的湿度
data2 = [-2,4,5,2,7,8,11,13,12,10,9,4,6,4,3,2]
x = range(0,len(data1))
#   2:创建画布
fig,ax1 = plt.subplots()
#   3:绘制图像
ax1.plot(x,data1,label='温度')
plt.yticks(range(min(data1),max(data1)+1))
#设置共享X轴
ax2 = ax1.twinx()
#   5:绘制图像
ax2.plot(x,data2,label='湿度',color='r')
plt.yticks(range(min(data2),max(data2)+1))

#显示图例
fig.legend()

#方法二
#   1;准备数据
#  1天24小时的温度
data1 = [-5,1,5,2,6,8,11,13,12,10,9,4,6,4,3,2]
#  1天24小时的湿度

data2 = [-2,4,5,2,7,8,11,13,12,10,9,4,6,4,3,2]
x = range(0,len(data1))
#   2:创建画布
fig,ax1 = plt.subplots()
#   3:绘制图像
ax1.plot(x,data1,label='温度')
ax1.set_yticks(range(min(data1),max(data1)+1))
#设置共享X轴
ax2 = ax1.twinx()
#   5:绘制图像
ax2.plot(x,data2,label='湿度',color='r')
ax2.set_yticks(range(min(data2),max(data2)+1))

#显示图例
fig.legend()

Matplotlib网格与标题

pyplot.grid

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

# 1:设置表格
data = [-5,1,4,7,3,6,5,7,3,7,3,9,6]
x = range(1,len(data)+1)

plt.plot(x,data)
plt.grid(axis='x',ls='--',lw=1,c='gray',alpha=0.4)      

pyplot.title 与 pyplot.suptitle

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False


#2:设置标题

data = [-5,1,4,7,3,6,5,7,3,7,3,9,6]
x = range(1,len(data)+1)

plt.plot(x,data)
plt.title('一日温度',fontsize = 16) #设置标题方法一
plt.suptitle("2030年1月1日温度",fontsize = 16)#设置标题方法二

Matplotlib绘制文本

pyplot.text方法

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

# 绘制文本
data = [-5,1,4,7,-3,6,5,7,4,7,3,9,6]
x = range(1,len(data)+1)

plt.plot(x,data,marker='o',linestyle='--')
for i,j in zip(x,data):
    # ha 横向的对齐方式
    # va 纵向的对齐方式
    plt.text(i+0.3,j,j,fontsize = 16,color='black',ha='center',va='center')

Matplotlib注释的使用

pyplot.annotate方法

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

# 注释的使用
data = [-5,1,4,7,-3,6,9,6,4,7,8,8,6]
x = range(1,len(data)+1)
#获取最大值
max_value = max(data)
max_index = data.index(max_value)+1

min_value = min(data)
min_index = data.index(min_value)+1

plt.plot(x,data,marker='o',ls = '--')
plt.annotate(
    '最大值',    #注释文本
    xy = (max_index,max_value),   #注释点
    xytext=(max_index+1,max_value-1),   #注释文本位置
    arrowprops={
        'width':2,              #箭头宽度
        'facecolor':'black',    #箭头颜色
        'headlength':5,         #箭头长度
        'headwidth':6,          #箭头宽度
        'shrink':0.2,           #箭头收缩比例
    }
    )

plt.annotate(
    '最小值',
    xy = (min_index,min_value),
    xytext=(min_index+1,min_value+1),
    arrowprops={
        'width':2,
        'facecolor':'black',
        'headlength':5,
        'headwidth':6,
        'shrink':0.2,
    }
    )

Matplotlib保存图表

pyplot.savefig

python 复制代码
from matplotlib import pyplot as plt

#设置中文字体
plt.rcParams['font.sans-serif'] = 'SimHei'
#显示正常显示符号
plt.rcParams['axes.unicode_minus'] = False

data = [-5,1,4,7,-3,6,9,6,4,7,8,8,6]
x = range(1,len(data)+1)

ata = [-5,1,4,7,3,6,5,7,3,7,3,9,6]
x = range(1,len(data)+1)

plt.plot(x,data)
plt.grid(axis='x',ls='--',lw=1,c='gray',alpha=0.4) 
plt.suptitle("2030年1月1日温度",fontsize = 16)

plt.savefig('./img/line1')
plt.savefig('./img/line2.png')
plt.savefig('./img/line3.jpg')
plt.savefig('./img/line4.svg')
plt.savefig('./img/line5.pdf')
plt.savefig('./img/line6.png',dpi=200)
plt.savefig('./img/line7.png',dpi=500)
plt.savefig('./img/line8.png',facecolor='gray')
plt.savefig('./img/line9.png',pad_inches=10)
相关推荐
Bigemap软件2 天前
【无标题】保姆级教程|河道中心线自动化渲染+水质监测可视化,全流程一步到位
数据可视化·测绘·国产gis软件·bigemappro·河流污染热力图
山海鲸实战案例分享2 天前
【数字孪生实战案例】怎样在可视化场景内实现模型裁切操作?~山海鲸可视化
数字孪生·数据可视化·零代码·实战案例·山海鲸可视化·三维场景·裁切
极光代码工作室3 天前
基于大数据的交通流量分析系统
大数据·hadoop·python·数据分析·数据可视化
SZLSDH3 天前
数字孪生IOC的“双引擎”架构:当业务编排遇上渲染管线,如何实现场景适配?
数据库·ai·架构·数字孪生·数据可视化·智能体
Strayer5 天前
在地图上实现管网拓扑批量移动、旋转与缩放(参考图片的实现方式)
gis·webgl·数据可视化
谙弆悕博士5 天前
R 语言学习笔记
笔记·学习·数据分析·r语言·数据可视化
盼兮6 天前
用AI编程从零搭建一个响应式数据看板
前端·人工智能·数据可视化
余丁,微生信6 天前
上下调基因可视化新视角:半圆图的直观之美
数据分析·数据可视化·论文插图·生信分析·科研绘图·科学科普·差异基因
山海鲸可视化6 天前
数字孪生项目案例 | 物流园区可视化
webgl·可视化·数据可视化·数据表格·搜索框