相信有很多人曾經(jīng)被matplotlib畫圖的中文顯示問題所困擾做裙,包括我自己。每次生產(chǎn)環(huán)境發(fā)生改變肃晚,都會遭遇到這個問題锚贱,然后需要花大量的時間在它上邊。最可氣的是每次遇到的問題不一定一樣关串,上一次使用的方法不一定適用拧廊。網(wǎng)上的教程很多,但沒有看到一個完整的晋修、必殺的解決方案吧碾。
我在花了大量時間進行多次嘗試之后,總結(jié)出了一套流程墓卦,截止目前我遇到過的所有的不同環(huán)境下(Linux + Mac)的matplotlib中文顯示問題都得到了完美解決倦春,因此整理出來分享給大家,希望能讓大家少走彎路落剪,把時間花在更有價值的地方睁本。
剛好我購置了一臺騰訊云的服務(wù)器,我們就拿它為例忠怖,看一下如何配置呢堰。
首先我們安裝好Python3+matplotlib,然后進入Python脑又,畫一張圖來看看效果:
import matplotlib.pyplot as plt
plt.plot([1,3,2,4], '--r')
plt.title(u'測試')
plt.savefig('temp.png')
可以看到雖然我們?yōu)?code>title設(shè)置了中文“測試”暮胧,但實際上顯示出來的卻是兩個方框锐借。好,那我們就開始解決這個問題往衷。
第一步:確認系統(tǒng)字體
我們在命令行中通過fc-list :lang=zh
來查看下系統(tǒng)是否有安裝中文字體钞翔。
# root @ VM_0_16_centos in ~ [14:20:29]
$ fc-list :lang=zh
# root @ VM_0_16_centos in ~ [14:22:01]
$
我們看到輸出為空,這說明我們的Linux系統(tǒng)暫時沒有安裝中文字體席舍,我們需要進行安裝布轿。老版本有很多種安裝方法,有一些甚至需要root權(quán)限来颤,這一點很不友好汰扭。因為很多朋友的服務(wù)器是公司提供的,出于安全考慮福铅,普通技術(shù)員工并沒有root權(quán)限萝毛。
好在現(xiàn)在絕大多數(shù)的linux版本都已經(jīng)可以非常快速地通過復制文件的方式來安裝字體了滑黔。
我們先下載喜歡的中文字體笆包,比如黑體、楷體和微軟雅黑略荡。下載好之后庵佣,我們將文件上傳到服務(wù)器,并移動到個人目錄下的.fonts
文件夾內(nèi)汛兜。
然后巴粪,我們再檢查一下:
# root @ VM_0_16_centos in ~ [14:27:46]
$ fc-list :lang=zh
/root/.fonts/msyh.ttf: 微軟雅黑,Microsoft YaHei:style=Regular
/root/.fonts/simhei.ttf: 黑體,SimHei:style=Regular,Normal,oby?ejné,Standard,Κανονικ?,Normaali,Normál,Normale,Standaard,Normalny,Обычный,Normálne,Navadno,Arrunta
/root/.fonts/simkai.ttf: 楷體_GB2312,KaiTi_GB2312:style=Regular
可以看到,我們已經(jīng)成功地將三個中文字體安裝到了系統(tǒng)中粥谬,是不是很簡單快速肛根?
第二步:安裝matplotlib字體支持
接下來我們要在matplotlib中安裝中文字體(這一步在有些教程里是不需要的,但是時靈時不靈帝嗡,我們最好也安裝一下晶通。),這一步需要我們先確認字體的安裝目錄哟玷。
In [9]: import matplotlib as mpl
In [10]: mpl.matplotlib_fname()
Out[10]: '/usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data/matplotlibrc'
我們看到了matplotlib的配置文件的地址狮辽,記住這個地址,后邊修改配置時要用到〕补眩現(xiàn)在我們用它來定位字體文件夾喉脖。我們進入配置文件所在目錄:
# root @ VM_0_16_centos in ~ [14:41:22] C:1
$ cd /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data/
# root @ VM_0_16_centos in /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data [14:41:24]
$ ll
總用量 52K
drwxr-xr-x 5 root root 4.0K 11月 30 14:03 fonts
drwxr-xr-x 2 root root 4.0K 11月 30 14:03 images
-rw-r--r-- 1 root root 33K 11月 30 14:03 matplotlibrc
drwxr-xr-x 3 root root 4.0K 11月 30 14:03 sample_data
drwxr-xr-x 2 root root 4.0K 11月 30 14:03 stylelib
# root @ VM_0_16_centos in /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data [14:41:25]
$ cd fonts
# root @ VM_0_16_centos in /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data/fonts [14:41:29]
$ ll
總用量 12K
drwxr-xr-x 2 root root 4.0K 11月 30 14:03 afm
drwxr-xr-x 2 root root 4.0K 11月 30 14:03 pdfcorefonts
drwxr-xr-x 2 root root 4.0K 11月 30 14:03 ttf
# root @ VM_0_16_centos in /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data/fonts [14:41:31]
$ cd ttf
# root @ VM_0_16_centos in /usr/local/lib64/python3.6/site-packages/matplotlib/mpl-data/fonts/ttf [14:41:33]
$ ll
總用量 6.7M
-rw-r--r-- 1 root root 26K 11月 30 14:03 cmb10.ttf
-rw-r--r-- 1 root root 21K 11月 30 14:03 cmex10.ttf
-rw-r--r-- 1 root root 32K 11月 30 14:03 cmmi10.ttf
-rw-r--r-- 1 root root 26K 11月 30 14:03 cmr10.ttf
-rw-r--r-- 1 root root 20K 11月 30 14:03 cmss10.ttf
-rw-r--r-- 1 root root 29K 11月 30 14:03 cmsy10.ttf
-rw-r--r-- 1 root root 28K 11月 30 14:03 cmtt10.ttf
......
好了,接下來我們將剛才的字體文件復制過來即可抑月。
第三步:修改matplotlib配置文件
我們先關(guān)閉所有的Python程序树叽,包括Python、IPython谦絮、Jupyter等题诵,因為一會兒修改完之后需要清空緩存并重啟程序生效洁仗。
還記得剛才的matplotlibrc的地址吧,我們用趁手的文本編輯器打開它性锭,去掉如下三行開頭的注釋符赠潦,并在font.sans-serif的取值中,將我們剛才三個字體的英文名稱添加到最前邊草冈。英文名稱在我們剛才使用fc-list :lang=zh
時可以看到她奥。
axes.unicode_minus : True
font.family : sans-serif
font.sans-serif : Microsoft YaHei, SimHei, KaiTi_GB2312, DejaVu Sans, Bitstream Vera Sans, ...
保存退出。
這一步需要注意的是怎棱,如果你的系統(tǒng)中存在多個Python環(huán)境哩俭,那一定要確保你安裝的字體以及修改的配置文件是你要使用的那一個環(huán)境中的。
第四步:刪除緩存
不刪除緩存的話拳恋,在代碼中指定字體文件或字體名稱理論上也可以使用凡资,但這樣太麻煩 ,我們要解決就解決徹底谬运。
一般情況下脐瑰,緩存在~/.cache/matplotlib
目錄下道偷,但也有些會在~/.matplotlib
目錄下(我的Mac是這樣的)滨彻,不管在哪里前塔,我們直接清除掉這個目錄即可膝藕。
rm -rf ~/.cache/matplotlib
或者
rm -rf ~/.matplotlib
第五步:重啟Python程序
現(xiàn)在我們重新打開我們的Python程序式廷,檢查一下是否已經(jīng)好了。
import matplotlib.pyplot as plt
plt.plot([1,3,2,4], '--r')
plt.title(u'測試')
plt.savefig('temp.png')
大功告成芭挽,我們的title
成功地顯示出來了滑废。
第六步:針對Python2的補充
另外說一點,由于Python2默認的編碼方式并不是UTF-8
袜爪,因此在Python2中蠕趁,我們要在字符串之前添加u
,強制將字符串以Unicode方式編碼辛馆。如上例俺陋,在Python2中,我們應(yīng)該使用u"測試"
昙篙。
以上就是我梳理的完整的解決流程腊状,如有嚴格按照此流程操作仍不能解決的,可以聯(lián)系我苔可,我們一起探討缴挖。