python matplotlib解决中文乱码问题

问题描述

python中数据可视化工具matplotlib的使用方法,但在有的时候我们使用这个模块会出现中华文乱码的情况 在用matplotlib现实中文数据时,会出现乱码的情况 如下:

python matplotlib解决中文乱码问题_第1张图片

之所以会出现这种问题,是python在很多时候不支持中文代码,需要通过一定的说明代码才能够正常运行

配置步骤

1.导入中文字体字体库

下载中文字体库

wget -c http://d.xiazaiziti.com/en_fonts/fonts/s/SimHei.ttf

拷贝字体到 /usr/share/fonts 下

cp -rf SimHei.ttf /usr/share/fonts/

2.删除缓存文件

删除~/.matplotlib中的缓存文件

rm -rf ~/.cache/matplotlib/*

3.配置方法

方法一:通过参数字典 rcParams 修改已经加载的配置项

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

方法二:如通过修改配置项无法满足,在有中文输出的地方,增加一个属性:fontproperties

from matplotlib.font_manager import *
myfont = FontProperties(fname='/usr/share/fonts/SimHei.ttf')

示例代码

import matplotlib.pyplot as plt
from matplotlib.font_manager import *
myfont = FontProperties(fname='/usr/share/fonts/SimHei.ttf')
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
# 0.准备数据
# 电影名字
movie_name = ['雷神3:诸神黄昏','正义联盟','东方快车谋杀案','寻梦环游记','全球风暴','降魔传','追捕','七十七天','密战','狂兽','其它']
# 横坐标
x = range(len(movie_name))
# 票房数据
y = [73853,57767,22354,15969,14839,8725,8716,8318,7916,6764,52222]
​
# 1.创建画布
plt.figure(figsize=(20, 8), dpi=100)
​
# 2.绘制柱状图
plt.bar(x, y, width=0.5, color=['b','r','g','y','c','m','y','k','c','g','b'])
​
# 2.1b修改x轴的刻度显示
plt.xticks(x, movie_name,FontProperties=myfont)
​
# 2.2 添加网格显示
plt.grid(linestyle="--", alpha=0.5)
​
# 2.3 添加标题
plt.title("电影票房收入对比",FontProperties=myfont)
​
# 3.显示图像
plt.show()

现实效果

python matplotlib解决中文乱码问题_第2张图片

你可能感兴趣的:(python,matplotlib,python,开发语言)