0

0

matplotlib 如何让中文不乱码 + 负号正常显示(永久配置)

舞夢輝影

舞夢輝影

发布时间:2026-01-24 19:31:02

|

797人浏览过

|

来源于php中文网

原创

Matplotlib中文乱码的根本原因是默认字体不支持中文且字体查找机制跳过系统中文字体,同时mathtext将减号映射为U+2212而中文字体通常不覆盖该码位。

matplotlib 如何让中文不乱码 + 负号正常显示(永久配置)

VanceAI Image Resizer
VanceAI Image Resizer

VanceAI推出的在线图片尺寸调整工具

下载

matplotlib 中文乱码的根本原因是什么 Matplotlib 默认字体不支持中文,且其字体查找机制会跳过系统中已安装的中文字体;同时,默认字体(如 DejaVu Sans)不包含中文字符映射,导致显示为方块。负号(-)显示为方块或空格,是因为 Matplotlib 将减号当作数学符号,启用 mathtext 渲染时默认使用 STIX 或 Computer Modern 字体——它们也不含中文,且对 ASCII 减号做了 Unicode 映射替换(变成 U+2212 MINUS SIGN),而中文字体通常不覆盖该码位。

临时解决:每次绘图前手动设置字体 这不是永久方案,但能快速验证是否字体路径/名称正确:
  • 先查系统中可用的中文字体:matplotlib.font_manager.findSystemFonts(fontpaths=None, fontext='ttf'),然后用 matplotlib.font_manager.FontProperties 加载
  • 更常用的是直接指定字体名(注意不是文件名):plt.rcParams['font.sans-serif'] = ['SimHei', 'KaiTi', 'Microsoft YaHei', 'AR PL UKai CN']
  • 必须关闭无衬线字体的数学渲染干扰:plt.rcParams['axes.unicode_minus'] = False(否则负号仍变方块)
示例:
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['Microsoft YaHei']
plt.rcParams['axes.unicode_minus'] = False
plt.plot([1, 2, 3], [-10, -5, 0])
plt.title('温度变化趋势')
plt.show()

永久配置:修改 matplotlib 配置文件 matplotlibrc 永久生效的关键是改对文件——不是 Python site-packages 下的模板,而是用户级配置目录下的实际生效文件:
  • 运行 matplotlib.get_configdir() 查到路径(如 ~/.matplotlibC:\Users\XXX\.matplotlib
  • 在该目录下新建或编辑 matplotlibrc(无后缀),添加三行:
font.sans-serif: Microsoft YaHei, SimHei, KaiTi, sans-serif
axes.unicode_minus: False
axes.titlesize: medium
注意:font.sans-serif 值列表里**不能有空格分隔的逗号以外的空白**(如 Microsoft YaHei , SimHei 会失败);顺序代表 fallback 优先级,建议把最稳定、系统必有的字体放前面。

Windows / macOS / Linux 各平台字体名差异与避坑点 不同系统预装字体名不一致,硬写死一个名字容易失效:
  • Windows 推荐用:Microsoft YaHei(微软雅黑)、SimHei(黑体),避免用 NSimSun(新宋体)——它不支持粗体变体,title 加粗会回退失败
  • macOS 可用:Heiti SC(黑体-简)、Hiragino Sans GB,但需确认是否在 findSystemFonts() 结果里出现(某些版本需手动安装)
  • Linux(如 Ubuntu)常见问题:系统自带的 Noto Sans CJK SC 在 matplotlib 中注册名为 Noto Sans CJK JPAR PL UMing CN,建议先运行 fc-list :lang=zh 查真实名称
  • 所有平台都建议加一个兜底项 sans-serif,防止前面全失效时至少不报错
改完配置后,**必须重启 Python 解释器或 Jupyter kernel**,因为 matplotlib.rcParams 在模块导入时就已初始化完毕,运行时改 matplotlibrc 文件不会自动重载。 字体配置看着简单,但实际生效依赖字体文件存在、名称拼写精确、fallback 顺序合理、以及 mathtext 开关匹配——漏掉任意一环,中文或负号就可能突然“消失”。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

773

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

684

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

765

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

719

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1425

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

751

2023.08.11

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号