[AI工具从入门到入土] matplotlib

[AI工具从入门到入土] matplotlib🎨

个人导航

知乎:https://www.zhihu.com/people/byzh_rc

CSDN:https://blog.csdn.net/qq_54636039

注:本文仅对所述内容做了框架性引导,具体细节可查询其余相关资料or源码

参考文章:各方资料

文章目录

  • [[AI工具从入门到入土] matplotlib:art:](#[AI工具从入门到入土] matplotlib:art:)
  • 个人导航
  • :pushpin:规范
        • [1. `plt`方式](#1. plt方式)
        • [2. `ax`方式](#2. ax方式)
  • :gear:导入
  • :gear:全局设置
  • :framed_picture:画布
  • 基础细节
        • [1. 标题](#1. 标题)
        • [2. 图例](#2. 图例)
        • [3. 坐标轴标签](#3. 坐标轴标签)
        • [4. 坐标轴刻度](#4. 坐标轴刻度)
        • [5. 边框](#5. 边框)
        • [6. 网格线](#6. 网格线)
  • 文本
  • 保存
  • [拓展 - 修改已有legend](#拓展 - 修改已有legend)
  • [拓展 - 排版](#拓展 - 排版)

📌规范

1. plt方式

全局级 -> 直接作用于当前图标

2. ax方式

对象级 -> 精准作用于指定对象

⚙️导入

py 复制代码
import matplotlib.pyplot as plt
from matplotlib.axes import Axes # 为ax提供类型提示

# 正常显示中文和负号
plt.rcParams['font.sans-serif'] = ['SimHei', 'Kaiti', 'Microsoft YaHei']  
plt.rcParams['axes.unicode_minus'] = False

⚙️全局设置

py 复制代码
plt.rcParams['font.size'] = 12       # 默认字体大小
plt.rcParams['axes.titlesize'] = 14  # 标题字体大小
plt.rcParams['axes.labelsize'] = 12  # 坐标轴标签字体大小
plt.rcParams['xtick.labelsize'] = 10 # x轴刻度字体大小
plt.rcParams['ytick.labelsize'] = 10 # y轴刻度字体大小
plt.rcParams['legend.fontsize'] = 10 # 图例字体大小

🖼画布

常用:

py 复制代码
plt.figure(figsize=(12, 6))

单图:

py 复制代码
# 麻烦
fig = plt.figure(figsize=(12, 6))
ax = plt.gca() # get current axes
py 复制代码
# 不推荐
fig = plt.figure(figsize=(12, 6))
ax = fig.add_subplot(111) # 1行1列第1个子图
py 复制代码
# 推荐
fig, ax = plt.subplots(figsize=(12, 6))

多图:

py 复制代码
fig, axs = plt.subplots(nrows=2, ncols=1, figsize=(12, 6), constrained_layout=True)

对于多图, 还可使用 axs = axs.flatten()

基础细节

1. 标题
py 复制代码
plt.title('xxx', fontsize=16, pad=20, fontweight='bold')
py 复制代码
ax.set_title('xxx', fontsize=16, pad=20, fontweight='bold')
2. 图例
py 复制代码
plt.legend(fontsize=17, loc='upper right')
plt.legend(fontsize=17, loc='lower left')
py 复制代码
ax.legend(fontsize=17, loc='upper right')
ax.legend(fontsize=17, loc='lower left')
3. 坐标轴标签
py 复制代码
plt.xlabel('xxx', fontsize=17, labelpad=10)
plt.ylabel('xxx', fontsize=17, labelpad=10)
py 复制代码
ax.set_xlabel('xxx', fontsize=17, labelpad=10) 
ax.set_ylabel('xxx', fontsize=17, labelpad=10)
4. 坐标轴刻度
复制代码
plt.xticks(fontsize=17)
plt.yticks(fontsize=17)
py 复制代码
ax.tick_params(axis='x', labelsize=17)
ax.tick_params(axis='y', labelsize=17)
5. 边框
py 复制代码
ax = plt.gca()
ax.spines['right'].set_visible(False)
ax.spines['left'].set_visible(False)
ax.spines['top'].set_visible(False)
ax.spines['bottom'].set_visible(False)
6. 网格线
py 复制代码
plt.grid(axis='x', linestyle='--', alpha=0.7, color='gray')
plt.grid(axis='y', linestyle='--', alpha=0.7, color='gray')
py 复制代码
ax.grid(axis='x', linestyle='--', alpha=0.7, color='gray')
ax.grid(axis='y', linestyle='--', alpha=0.7, color='gray')

文本

py 复制代码
plt.text(
    0.5, 0.5, 'xxx',
    ha='center', va='center',
    fontsize=14, fontweight='bold', color='#555555',
    transform=plt.gca().transAxes
)
py 复制代码
ax.text(
    0.5, 0.5, 'xxx',
    ha='center', va='center',
    fontsize=14, fontweight='bold', color='#555555',
    transform=plt.gca().transAxes
)

保存

py 复制代码
plt.savefig("fig.png", dpi=300, bbox_inches='tight')
plt.close()

拓展 - 修改已有legend

py 复制代码
leg = ax.get_legend()

leg.set_frame_on(False)
for text in leg.get_texts():
    text.set_fontsize(17)

拓展 - 排版

名字 作用阶段 作用对象
constrained_layout=True 🟢 创建时 整个布局系统
tight_layout() 🟡 绘图后 子图之间间距
bbox_inches='tight' 🔵 保存时 图片裁剪

constrained_layout=True: 新方案(智能布局引擎)

  • 避免标题重叠, 避免 label 重叠, 避免 legend 挤压

tight_layout(): 老方案

  • 调整子图间距, 避免基本重叠
  • 对 legend / colorbar 支持差, 有时会"挤坏布局"

bbox_inches='tight':

  • 去掉外围空白
  • 裁剪成"刚好包住内容"

-> 推荐使用 constrained_layout=Truebbox_inches='tight'

相关推荐
美酒没故事°20 小时前
Open WebUI安装指南。搭建自己的自托管 AI 平台
人工智能·windows·ai
云烟成雨TD20 小时前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
AI攻城狮20 小时前
用 Obsidian CLI + LLM 构建本地 RAG:让你的笔记真正「活」起来
人工智能·云原生·aigc
鸿乃江边鸟20 小时前
Nanobot 从onboard启动命令来看个人助理Agent的实现
人工智能·ai
lpfasd12320 小时前
基于Cloudflare生态的应用部署与开发全解
人工智能·agent·cloudflare
俞凡20 小时前
DevOps 2.0:智能体如何接管故障修复和基础设施维护
人工智能
comedate21 小时前
[OpenClaw] GLM 5 关于电影 - 人工智能 - 的思考
人工智能·电影评价
财迅通Ai21 小时前
6000万吨产能承压 卫星化学迎来战略窗口期
大数据·人工智能·物联网·卫星化学
liliangcsdn21 小时前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
GISer_Jing21 小时前
Page-agent MCP结构
前端·人工智能