linux 环境下matplotlib 画图时不支持中文解决方案

在 Linux 环境下解决 matplotlib 绘图中文显示异常(乱码/方框)的问题,可通过以下步骤配置中文字体支持:


完整解决方案

1. 安装中文字体(以 SimHei 为例)

bash 复制代码
# 下载 SimHei 字体到系统字体目录
sudo wget -O /usr/share/fonts/SimHei.ttf https://zihao-openmmlab.obs.cn-east-3.myhuaweicloud.com/20220716-mmclassification/dataset/SimHei.ttf

# 更新字体缓存
sudo fc-cache -fv

2. 修改 matplotlib 配置文件

bash 复制代码
# 定位 matplotlib 配置文件路径(通常在以下位置)
python -c "import matplotlib; print(matplotlib.matplotlib_fname())"

# 编辑配置文件(例如路径为 ~/.config/matplotlib/matplotlibrc)
nano ~/.config/matplotlib/matplotlibrc

在配置文件中修改或添加以下参数:

ini 复制代码
font.family         : sans-serif
font.sans-serif     : SimHei, DejaVu Sans, Bitstream Vera Sans, Lucida Grande, Verdana, Geneva, Lucid, Arial, Helvetica, Avant Garde, sans-serif
axes.unicode_minus  : False  # 解决负号显示异常

3. 清除 matplotlib 缓存

bash 复制代码
rm -rf ~/.cache/matplotlib

4. 代码中显式指定字体(推荐)

python 复制代码
import matplotlib.pyplot as plt

plt.rcParams['font.sans-serif'] = ['SimHei']  # 指定默认字体
plt.rcParams['axes.unicode_minus'] = False    # 解决负号显示问题

# 测试绘图
plt.plot([1, 2, 3], [4, 5, 6])
plt.title("中文标题测试")
plt.xlabel("X轴")
plt.ylabel("Y轴")
plt.show()

验证是否成功

bash 复制代码
# 检查 matplotlib 可用字体列表是否包含 SimHei
python -c "from matplotlib.font_manager import FontManager; print([f.name for f in FontManager().ttflist if 'SimHei' in f.name])"

若输出包含 SimHei,则配置成功。


常见问题排查

  1. 字体路径错误

    • 确保字体文件已正确复制到 /usr/share/fonts/~/.fonts/ 目录。
    • 执行 fc-list | grep SimHei 检查字体是否被系统识别。
  2. 缓存未更新

    • 删除 ~/.cache/matplotlib 并重启 Python 进程。
  3. 代码冲突

    • 避免在代码中重复设置 font.sans-serif 或在局部使用 fontproperties 参数覆盖全局配置。

通过以上步骤,可彻底解决 Linux 下 matplotlib 中文显示问题。若需其他字体(如宋体、楷体),方法同理,只需替换对应的字体文件即可。

相关推荐
星辰徐哥21 分钟前
Spring Boot 微服务架构设计与实现
spring boot·后端·微服务
星辰徐哥21 分钟前
Spring Boot 数据导入导出与报表生成
spring boot·后端·ui
明夜之约22 分钟前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee23 分钟前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Micro麦可乐24 分钟前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
Jinkxs25 分钟前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
毕设源码_郑学姐26 分钟前
计算机毕业设计springboot网络相册设计与实现 基于Spring Boot框架的在线相册管理系统开发与应用 Spring Boot驱动的网络影集设计与实践
spring boot·后端·课程设计
辣机小司26 分钟前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
码农阿豪30 分钟前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
追逐时光者35 分钟前
一个基于 .NET 与 Avalonia 构建、面向 TrinityCore 的开源 WoW 数据库编辑器
后端·.net