[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'

相关推荐
大龄程序员狗哥23 分钟前
第47篇:使用Speech-to-Text API快速构建语音应用(操作教程)
人工智能
KKKlucifer23 分钟前
数据安全合规自动化:策略落地、审计追溯与风险闭环技术解析
人工智能·安全
RWKV元始智能34 分钟前
RWKV超并发项目教程,RWKV-LM训练提速40%
人工智能·rnn·深度学习·自然语言处理·开源
dyj09537 分钟前
Dify - (一)、本地部署Dify+聊天助手/Agent
人工智能·docker·容器
墨染天姬44 分钟前
【AI】Hermes的GEPA算法
人工智能·算法
小超同学你好1 小时前
OpenClaw 深度解析系列 · 第8篇:Learning & Adaptation(学习与自适应)
人工智能·语言模型·chatgpt
紫微AI1 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
码途漫谈1 小时前
Easy-Vibe开发篇阅读笔记(四)——前端开发之结合 Agent Skills 美化界面
人工智能·笔记·ai·开源·ai编程
易连EDI—EasyLink1 小时前
易连EDI–EasyLink实现OCR智能数据采集
网络·人工智能·安全·汽车·ocr·edi
冬奇Lab1 小时前
RAG 系列(二):用 LangChain 搭建你的第一个 RAG Pipeline
人工智能·langchain·llm