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)
相关推荐
千桐科技3 天前
数字孪生泵站安全监测实战:从“事后抢修”到“预知大脑”
大数据·数字孪生·数据可视化·智慧水利
Cthy_hy3 天前
浏览器市场分析——数据大屏动态数据接入
信息可视化·etl·数据可视化
一晌小贪欢3 天前
第19节:地理空间分析——使用 Geopandas 绘制热力地图
开发语言·python·数据分析·pandas·数据可视化
weixin_505154464 天前
打通工业安全治理“最后一公分”:Bowell 发布 Runtime 治理平台
大数据·人工智能·安全·3d·数字孪生·数据可视化
无心使然4 天前
OpenLayers 10.9.0 渲染架构分析
前端·gis·数据可视化
易知微EasyV数据可视化5 天前
从卫星影像到法线贴图:为任意区域一键生成真实地形材质
经验分享·ai·数字孪生·材质·数据可视化·贴图
牛猫Data6 天前
POWER BI技巧:报告名称的Emoji符号妙用
microsoft·数据分析·数据可视化·powerbi
SZLSDH6 天前
可视分析与自主决策之间:数字孪生与AI智能体融合的架构演进路径
ai·数字孪生·数据可视化·智能体
SZLSDH6 天前
从“可视化呈现”到“业务可编排”:数字孪生应用开发的逻辑演进
ai·数字孪生·数据可视化·智能体
SZLSDH7 天前
从“高保真镜像”到“智能体集群”:数字孪生应用演进的工程适配逻辑
ai·数字孪生·数据可视化·智能体