欢迎来到徐庆高(Tea)的个人博客网站
磨难很爱我,一度将我连根拔起。从惊慌失措到心力交瘁,我孤身一人,但并不孤独无依。依赖那些依赖我的人,信任那些信任我的人,帮助那些给予我帮助的人。如果我愿意,可以分裂成无数面镜子,让他们看见我,就像看见自己。察言观色和模仿学习是我的领域。像每个深受创伤的人那样,最终,我学会了随遇而安。
当前位置: 日志文章 > 详细内容

Python绘制三维填充折线图的示例代码

2025年07月09日 Python
在数据可视化领域,三维图形能够以更直观的方式展示数据之间的复杂关系。今天,我们将从头开始,一步步学习如何使用python中的matplotlib库绘制一个漂亮的三维填充折线图。即使你之前没有接触过py

在数据可视化领域,三维图形能够以更直观的方式展示数据之间的复杂关系。今天,我们将从头开始,一步步学习如何使用python中的matplotlib库绘制一个漂亮的三维填充折线图。即使你之前没有接触过python绘图,也不用担心,我们将详细解释每一步。

一、准备工作:安装必要的库

在开始之前,我们需要确保安装了numpymatplotlib这两个python库。如果你还没有安装它们,可以通过以下命令安装:

pip install numpy matplotlib

这两个库是python数据科学领域中非常基础且强大的工具,numpy用于高效处理数值数据,而matplotlib则用于数据可视化。

二、代码解析:一步步搭建三维填充折线图

1. 导入必要的模块

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d.art3d import polycollection
import matplotlib.cm as cm
import matplotlib
  • numpy(通常简写为np)用于生成和处理数据。
  • matplotlib.pyplot(简写为plt)是matplotlib中用于绘图的主要模块。
  • polycollection是用于创建三维填充区域的工具。
  • matplotlib.cm提供了丰富的颜色映射,用于给图形上色。
  • matplotlib用于设置全局绘图参数,比如字体和符号显示。

2. 设置中文和负号显示

matplotlib.rcparams['font.sans-serif'] = ['simhei']
matplotlib.rcparams['axes.unicode_minus'] = false

这两行代码是为了确保在图表中可以正常显示中文字符和负号。如果你的系统中没有simhei字体,可以替换为其他支持中文的字体。

3. 模拟数据

num_samples = 5
mz = np.linspace(0, 100, 300)
spectra = []
np.random.seed(0)
for i in range(num_samples):
    peak_positions = np.random.uniform(20, 80, 3)
    peak_heights = np.random.uniform(0.8, 1.5, 3)
    spectrum = sum(h * np.exp(-0.5 * ((mz - p)/3)**2) for p, h in zip(peak_positions, peak_heights))
    spectrum += np.random.normal(0, 0.05, len(mz))
    spectra.append(spectrum)

这里我们生成了一些模拟数据,用来展示图表的效果。num_samples表示我们有5个样本,mz是一个从0到100的线性分布的数组,表示质荷比(m/z)。spectra是一个列表,存储每个样本的光谱数据。

  • np.random.seed(0)是为了确保每次生成的数据都是一样的,方便我们复现结果。
  • peak_positionspeak_heights分别表示峰的位置和高度,它们是随机生成的。
  • spectrum是通过高斯函数生成的光谱数据,最后加上了一些随机噪声。

4. 创建图形

fig = plt.figure(figsize=(12, 7), facecolor='white')
ax = fig.add_subplot(111, projection='3d')
  • plt.figure创建了一个新的图形窗口,figsize参数设置了图形的大小,facecolor设置了背景颜色。
  • add_subplot添加了一个子图,projection='3d'表示这是一个三维图形。

5. 设置颜色和样本标签

colors = cm.viridis(np.linspace(0.2, 0.8, num_samples))
sample_labels = ['样本a', '样本b', '样本c', '样本d', '样本e']
  • cm.viridis是一个颜色映射,它会根据输入的值生成一系列颜色。这里我们生成了5种颜色,用于区分不同的样本。
  • sample_labels是一个列表,存储每个样本的标签。

6. 构建多边形区域

verts = []
for spectrum in spectra:
    verts.append(list(zip(mz, spectrum)))
poly = polycollection(
    verts,
    facecolors=colors,
    edgecolors='k',         # 添加黑色边框
    linewidths=0.6,         # 细边框
    alpha=0.85              # 稍微增强填充透明度
)
ax.add_collection3d(poly, zs=range(num_samples), zdir='y')
  • verts是一个列表,存储每个样本的多边形顶点。zip(mz, spectrum)将质荷比和对应的光谱强度组合起来。
  • polycollection用于创建填充的多边形区域,facecolors设置了填充颜色,edgecolorslinewidths设置了边框颜色和宽度,alpha设置了透明度。
  • add_collection3d将多边形区域添加到三维图形中,zszdir参数用于指定每个样本在三维空间中的位置。

7. 设置坐标轴和标题

ax.set_xlabel('质荷比 (m/z)', labelpad=12, fontsize=12, fontweight='bold')
ax.set_xlim(0, 100)
ax.set_ylabel('样本', labelpad=12, fontsize=12, fontweight='bold')
ax.set_ylim(-0.5, num_samples - 0.5)
ax.set_yticks(range(num_samples))
ax.set_yticklabels(sample_labels, fontsize=11)
ax.set_zlabel('离子强度', labelpad=10, fontsize=12, fontweight='bold')
ax.set_zlim(0, 1.6)
ax.set_title('提取的质谱子集', fontsize=14, fontweight='bold', pad=20)

这里我们设置了坐标轴的标签、范围、刻度标签和标题。labelpad参数用于调整标签的位置,fontsizefontweight分别设置字体大小和粗细。

8. 美化网格线和调整边距

ax.tick_params(axis='both', which='major', labelsize=10)
ax.grid(true, linestyle='--', linewidth=0.5, alpha=0.4)
fig.subplots_adjust(left=0.08, right=0.95, top=0.92, bottom=0.08)
  • tick_params设置了坐标轴刻度的字体大小。
  • grid添加了网格线,linestylelinewidthalpha分别设置了网格线的样式、宽度和透明度。
  • subplots_adjust调整了图形的边距,确保内容不会被遮挡。

9. 显示图形

plt.show()

最后,调用plt.show()就可以显示我们绘制的三维填充折线图了。

三、运行代码并查看结果

当你运行上述代码时,你会看到一个三维填充折线图。每个折线代表一个样本的光谱数据,填充区域的颜色表示不同的样本,如下图所示。

完整代码如下:

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d.art3d import polycollection
import matplotlib.cm as cm
import matplotlib
# 设置中文和负号显示
matplotlib.rcparams['font.sans-serif'] = ['simhei']
matplotlib.rcparams['axes.unicode_minus'] = false
# 模拟数据
num_samples = 5
mz = np.linspace(0, 100, 300)
spectra = []
np.random.seed(0)
for i in range(num_samples):
    peak_positions = np.random.uniform(20, 80, 3)
    peak_heights = np.random.uniform(0.8, 1.5, 3)
    spectrum = sum(h * np.exp(-0.5 * ((mz - p)/3)**2) for p, h in zip(peak_positions, peak_heights))
    spectrum += np.random.normal(0, 0.05, len(mz))
    spectra.append(spectrum)
# 创建图形
fig = plt.figure(figsize=(12, 7), facecolor='white')
ax = fig.add_subplot(111, projection='3d')
# 使用viridis色图
colors = cm.viridis(np.linspace(0.2, 0.8, num_samples))
sample_labels = ['样本a', '样本b', '样本c', '样本d', '样本e']
# 构建多边形区域
verts = []
for spectrum in spectra:
    verts.append(list(zip(mz, spectrum)))
poly = polycollection(
    verts,
    facecolors=colors,
    edgecolors='k',         
    linewidths=0.6,         
    alpha=0.85              
)
ax.add_collection3d(poly, zs=range(num_samples), zdir='y')
# 设置坐标轴
ax.set_xlabel('质荷比 (m/z)', labelpad=12, fontsize=12, fontweight='bold')
ax.set_xlim(0, 100)
ax.set_ylabel('样本', labelpad=12, fontsize=12, fontweight='bold')
ax.set_ylim(-0.5, num_samples - 0.5)
ax.set_yticks(range(num_samples))
ax.set_yticklabels(sample_labels, fontsize=11)
ax.set_zlabel('离子强度', labelpad=10, fontsize=12, fontweight='bold')
ax.set_zlim(0, 1.6)
# 标题
ax.set_title('提取的质谱子集', fontsize=14, fontweight='bold', pad=20)
# 网格线美化
ax.tick_params(axis='both', which='major', labelsize=10)
ax.grid(true, linestyle='--', linewidth=0.5, alpha=0.4)
# 调整边距
fig.subplots_adjust(left=0.08, right=0.95, top=0.92, bottom=0.08)
# 显示图
plt.show()

四、总结

通过以上步骤,我们用python和matplotlib库成功绘制了一个三维填充折线图。虽然代码看起来有点长,但其实每一步都很简单。你可以根据自己的需求修改数据、颜色和样式,制作出属于自己的图表。

到此这篇关于python绘制三维填充折线图的示例代码的文章就介绍到这了,更多相关python绘制折线图内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!