python--matplotlib(4)

简介: Python环境下实现Matlab制图功能的第三方库,需要numpy库的支持,支持用户方便设计出二维、三维数据的图形显示,制作的图形达到出版级的标准。

前言

Matplotlib画图工具的官网地址是 http://matplotlib.org/


Python环境下实现Matlab制图功能的第三方库,需要numpy库的支持,支持用户方便设计出二维、三维数据的图形显示,制作的图形达到出版级的标准。


其他matplotlib文章

python--matplotlib(1)_码银的博客-CSDN博客


python--matplotlib(2)_码银的博客-CSDN博客


python--matplotlib(3)_码银的博客-CSDN博客


实验环境

Pycharm2020.2.5社区版,win11


正文

三维立体图形:


除了要引用matplotlib外,还需要引用mpl_toolkits.mplot3d库(from mpl_toolkits.mplot3d import Axes3D),需要在matplotlib的figure函数生成实例对象后(fig = plt.figure()),设置其制图模式为3d(fig.add_subplot(111, projection='3d'))。


1.简单三维图

import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
fig = plt.figure()
sd = fig.add_subplot(111, projection='3d')#111,221,222,223,224
plt.show()

3f35b25d27a387ffa601d1c557c0907a_fc71951f8e8d4c5ba27dcb1cfcdf948c.png

import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
fig = plt.figure()
sd = fig.add_subplot(111, projection='3d')#111,221,222,223,224
X = [0, 1, 2, 1, 2, 4]
Y = [0, 4, 4, 1, 3, 4]
Z = [0, 4, 0, 0, 2, 4]
sd.plot_trisurf(X, Y, Z)
plt.show()

6b5e15f54af2ee99dd4383718202d368_e06d235f9f364e9fb7ee7144e26336eb.png


这个3d图可以转动,方便观察;


第四行代码:111,就是全屏或者或是正中间,剩下(221、222、223、224)对应四个角落,下面我依次截图看一下:

6859776fd05ae9b0bfc029bae1f54665_df0ab86fe68848d5b35cdd3f1772c6f0.png


6dcdad441fdd28eb6f95481b0a7c08d2_6a1231940bba4e499d62e1daf267fdfb.png

a8e23d5bcc2de751664c15ee4cc575cf_b77f3348d7dd4370b1e1be991fea5eb0.png


e4d1389db5ef0c32c896642c040edada_f76cfbb17b84473b958ae48e206a6ae4.png

plot_trisurf(z,y,z,...) :画3d曲平面的函数。


x,y,z要竖着看,一列对应的是一个点的坐标。


2.三维曲面plot_trisurf(薯片)

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
radius = np.linspace(0.1, 1, 25)
#np.linspace(start = 0.1, stop = 1, num = 25)
#stop 参数数值范围的终止点。通常其为结果的最后一个值,但如果修改endpoint = False, 则结果中不包括该值
angle = np.linspace(0, 2 * np.pi, 60, endpoint=False)
angle = np.repeat(angle[..., np.newaxis],25, axis=0)
#angles[..., np.newaxis]将每个元素转化为列表,np.repeat(a,repeats,axis=None);
# repeats:复制次数;axis=None,flatten当前矩阵,axis=0,增加行数,列数不变,axis=1,增加列数,行数不变
x = np.append(1, (radius * np.cos(angle)).flatten())
y = np.append(0, (radius * np.sin(angle)).flatten())
#flatten()是对多维数据的降维函数
y=y/2
x=x/2
z = np.sin(x * y)
z=z/2
fig = plt.figure()
sd = fig.add_subplot(projection='3d')
sd.plot_trisurf(x, y, z, cmap=plt.get_cmap('YlOrRd'), linewidth=0.1)
plt.show()

bbedb7accfcd75e703677210e549f1bd_06c6b554141f44dea159619dbb2d2413.png



a.导入库

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D

b.数据准备

radius = np.linspace(0.1, 1, 25)
angle = np.linspace(0, 2 * np.pi, 60, endpoint=False)
angle = np.repeat(angle[..., np.newaxis],25, axis=0)
x = np.append(1, (radius * np.cos(angle)).flatten())
y = np.append(0, (radius * np.sin(angle)).flatten())
y=y/2
x=x/2
z = np.sin(x * y)
z=z/2

linspace()函数


np.linspace(start = 0.1, stop = 1, num = 25)


start 参数数值范围的起始点。


stop 参数数值范围的终止点。通常其为结果的最后一个值,但如果修改endpoint = False, 则结果中不包括该值


num:数据数量,本篇选择了25个。



flatten()函数是对多维数据的降维函数,将矩阵的行之间首尾连接,组成一个一维矩阵;



repeat()函数


np.repeat(a,repeats,axis=0)


repeats:复制次数;


axis=None,把矩阵变成了一个一维矩阵[1,2,3,4];


axis=0,增加行数,列数不变;


axis=1,增加列数,行数不变


angles[..., np.newaxis]将每个元素转化为列表,


c.画图

fig = plt.figure()
sd = fig.add_subplot(projection='3d')
sd.plot_trisurf(x, y, z, cmap=plt.get_cmap('YlOrRd'), linewidth=0.1)
plt.show()

cmap:调换颜色的作用


linewidth:线宽


3.三维曲面标题等设置

import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams["font.sans-serif"] = ["SimHei"]# 正确显示中文和负号
plt.rcParams["axes.unicode_minus"] = False
fig = plt.figure()
sd = fig.add_subplot(111, projection='3d')#111,221,222,223,224
X = [0, 1, 2, 1, 2, 4]
Y = [0, 4, 4, 1, 3, 4]
Z = [0, 4, 0, 0, 2, 4]
sd.set_xlabel('x轴')
sd.set_ylabel('y轴')
sd.set_zlabel('z轴')
plt.title('这是标题')
sd.plot_trisurf(X, Y, Z)
plt.show()

0258524ec6aaf5ff75811c66b70c2eb8_1176c0f00b4641938d1b4703e965efe8.png


我就直接使用标题1里面的代码加工了,


sd.set_xlabel('x轴')#x轴函数


sd.set_ylabel('y轴')#y轴函数


sd.set_zlabel('z轴')#z轴函数


plt.title('这是标题')#添加标题函数


因为我使用了中文,


plt.rcParams["font.sans-serif"] = ["SimHei"]# 正确显示中文和负号

plt.rcParams["axes.unicode_minus"] = False


所以还得用这两行代码,要是仅仅使用英文的话删除即可。


4.小结

当初我第一次numpy库的时候的心得:使用pip install matplotlib安装matplotlib库,而 numpy 库我是在c:\users\yonghuming\appdata\local\programs\python\python39\scripts的目录下使用pip install numpy-1.22.4-cp39-cp39-win_amd64.whl才安装成功的。


现在我使用的是anaconda,直接把大部分的库安装好了,省时省力。

目录
相关文章
|
3月前
|
Java Python
Python tricksUnderscores, Dunders, and More
Python tricksUnderscores, Dunders, and More
23 0
|
5月前
|
数据采集 存储 文字识别
Python高手必备的9大技巧
Python高手必备的9大技巧
29 0
每天 3 分钟,小闫带你学 Python(八)
每天 3 分钟,小闫带你学 Python(八)
|
编解码 数据处理 索引
python xarray 简单介绍
python xarray 简单介绍
|
BI 测试技术 Python
每天一个Python小技巧(4)
每天一个Python小技巧(4)
每天一个Python小技巧(4)
|
Python
Python小技巧
One For All!!! 导包 取别名 from math as foobar from module1 import open as open1 from module2 import open as open2 查找Python的模块位置 >>> import sys,pprint >>> pprint.
835 0
|
Java Python Windows