Jupyter Notebook中解决matplotlib绘图中文乱码的实用方案

在使用 Jupyter Notebook 进行数据可视化时,调用 matplotlib.pyplot 绘图模块时出现中文乱码问题。无论是图例、标题、坐标轴标签中只要含有中文字符,就会显示为一串乱码或方框,影响图表的可读性。

该问题的出现主要是由于系统默认字体中不包含中文字体,而 matplotlib 在渲染时未找到支持中文的字体资源。

解决方案

要解决该问题,需要为 matplotlib 指定一款支持中文的字体,并通过 rcParamsFontProperties 设置生效。对于中文用户常用的方式是加载如 SimHei(黑体)或 Microsoft YaHei(微软雅黑)字体。

此外,为避免负号"-"在图中被错误渲染为方块,还需要单独设置 axes.unicode_minus=False

通过 matplotlib.font_manager 模块设置字体路径并载入中文字体。rcParams 是最常见的方式,也可在全局配置文件中修改,但这里以代码方式为主,便于直接在 Notebook 环境中生效。

python 复制代码
import matplotlib.pyplot as plt
import matplotlib
from matplotlib import rcParams

# 设置中文字体为 SimHei,解决中文乱码
rcParams['font.sans-serif'] = ['SimHei']
# 解决负号 '-' 显示为方块的问题
rcParams['axes.unicode_minus'] = False

# 示例绘图
x = [1, 2, 3]
y = [10, 20, 15]
plt.plot(x, y)
plt.title("示例折线图")
plt.xlabel("横坐标")
plt.ylabel("纵坐标")
plt.grid(True)
plt.show()

如果系统中没有 SimHei,可以使用 matplotlib.font_manager.FontProperties 指定本地已有的字体文件路径:

python 复制代码
from matplotlib.font_manager import FontProperties

# 设置字体路径
font_path = "/usr/share/fonts/truetype/arphic/ukai.ttc"  # 替换为实际路径
font = FontProperties(fname=font_path)

plt.plot(x, y)
plt.title("示例折线图", fontproperties=font)
plt.xlabel("横坐标", fontproperties=font)
plt.ylabel("纵坐标", fontproperties=font)
plt.grid(True)
plt.show()

设置字体后,图表中的标题、坐标轴、图例等元素均能正确显示中文字符,不再出现乱码或方框问题,图形展示效果符合中文环境使用需求。

该问题虽小但具有普遍性,在初学数据可视化时容易影响用户对 matplotlib 的直观印象。推荐在项目初始化或教学中预设好中文字体配置。更进一步,可封装字体设置为函数或创建模板图形函数,提升复用性。此外,在多平台(如 macOS、Linux、Windows)下需要注意字体名称和路径的差异性,建议根据操作系统条件进行字体自动适配,提升代码的通用性与可移植性。

相关推荐
wenzhangli71 天前
AI-IDE 关键技术解析:从自然语言到企业级智能开发平台的架构演进
ide·人工智能·架构
${王小剑}1 天前
在pycharm中配置pyside6
ide·python·pycharm
youcans_1 天前
【跟我学 AI 编程】(6) Claude Code 与 IDE 的集成
ide·人工智能·ai编程·claude code
闪电悠米1 天前
黑马点评-秒杀优化-01_async_seckill_idea
java·数据库·ide·redis·分布式·缓存·intellij-idea
摇滚侠1 天前
IDEA 创建 Java 项目 lib 和 resources
java·ide·intellij-idea
仰望星空的凡人1 天前
VSCODE接入Claude Code使用第三方模型教程
ide·vscode·ai智能体·claude code
棒棒的唐2 天前
Vscode Continue插件 集成 本地llama.cpp大模型实现代码补全
ide·vscode·编辑器
北暮城南2 天前
使用 Claude Code 高效实现图像边缘检测:多算法对比与工程实践
python·opencv·numpy·matplotlib·边缘检测·claude code
bush42 天前
vscode编辑设备树插件 devicetree LSP
ide·vscode·里氏替换原则
摇滚侠2 天前
IDEA 新建 JavaWeb 项目 Tomcat 和 Servlet
java·ide·intellij-idea