使用 LaTeX 渲染文本

原文:Text rendering With LaTeX

译者:飞龙

协议:CC BY-NC-SA 4.0

Matplotlib 可以选择使用 LaTeX 来管理所有文本布局。 此选项可用于以下后端:

  • Agg
  • PS
  • PDF

LaTeX 选项通过在rc设置中设置text.usetex:True来激活。 使用 matplotlib 的 LaTeX 支持的文本处理会慢于 matplotlib 的非常强大的 mathtext,但是更灵活,因为可以使用不同的 LaTeX 包(字体包,数学包等)。 结果会十分惊人,特别是当你在图形中使用和主文档相同的字体。

Matplotlib 的 LaTeX 支持需要可用的 LaTeX 安装版本,dvipng(可能包括在你的 LaTeX 安装中)和 Ghostscript(建议使用 GPL Ghostscript 8.60 或更高版本)。 这些外部依赖的可执行文件必须都位于你的PATH中。

有几个选项需要提及,可以使用rc设置更改它们。 这里是一个matplotlibrc示例文件:

font.family        : serif
font.serif         : Times, Palatino, New Century Schoolbook, Bookman, Computer Modern Roman
font.sans-serif    : Helvetica, Avant Garde, Computer Modern Sans serif
font.cursive       : Zapf Chancery
font.monospace     : Courier, Computer Modern Typewritertext.usetex        : true

每个系列中的第一个有效字体是要加载的字体。 如果未指定字体,则默认使用 Computer Modern 字体。 所有其他字体是 Adobe 字体。 Times 和 Palatino 每个都有自己附带的数学字体,而其他 Adobe 衬线字体使用 Computer Modern 数学字体。 有关更多详细信息,请参阅 PSNFSS 文档。

要使用 LaTeX 并选择 Helvetica 作为默认字体,但不编辑matplotlibrc,使用:

from matplotlib import rc
rc('font',**{'family':'sans-serif','sans-serif':['Helvetica']})
## for Palatino and other serif fonts use:
#rc('font',**{'family':'serif','serif':['Palatino']})
rc('text', usetex=True)

这里是标准的示例,tex_demo.py

"""
Demo of TeX rendering.You can use TeX to render all of your matplotlib text if the rc
parameter text.usetex is set.  This works currently on the agg and ps
backends, and requires that you have tex and the other dependencies
described at http://matplotlib.org/users/usetex.html
properly installed on your system.  The first time you run a script
you will see a lot of output from tex and associated tools.  The next
time, the run may be silent, as a lot of the information is cached in
~/.tex.cache"""
import numpy as np
import matplotlib.pyplot as plt# Example data
t = np.arange(0.0, 1.0 + 0.01, 0.01)
s = np.cos(4 * np.pi * t) + 2plt.rc('text', usetex=True)
plt.rc('font', family='serif')
plt.plot(t, s)plt.xlabel(r'\textbf{time} (s)')
plt.ylabel(r'\textit{voltage} (mV)',fontsize=16)
plt.title(r"\TeX\ is Number "r"$\displaystyle\sum_{n=1}^\infty\frac{-e^{i\pi}}{2^n}$!",fontsize=16, color='gray')
# Make room for the ridiculously large title.
plt.subplots_adjust(top=0.8)plt.savefig('tex_demo')
plt.show()

要注意数学显示模式($$ e=mc^2 $$)是不支持的,但是添加命令\displaystyle之后会产生相同结果,就像tex_demo.py中那样。

注意

一些字符在 TeX 中需要特别转义,例如:


# $ % & ~ _ ^ \ { } \( \) \[ \]

所以,这些字符会根据rcParam text.usetex标志位而表现不同。

在 TeX 中使用 Unicode

也可以在 LaTeX 文本管理器中使用 unicode 字符串,这里是从tex_unicode_demo.py中获取的示例:

# -*- coding: utf-8 -*-
"""
This demo is tex_demo.py modified to have unicode. See that file for
more information.
"""from __future__ import unicode_literals
import numpy as np
import matplotlib
matplotlib.rcParams['text.usetex'] = True
matplotlib.rcParams['text.latex.unicode'] = True
import matplotlib.pyplot as pltplt.figure(1, figsize=(6, 4))
ax = plt.axes([0.1, 0.1, 0.8, 0.7])
t = np.arange(0.0, 1.0 + 0.01, 0.01)
s = np.cos(2*2*np.pi*t) + 2
plt.plot(t, s)plt.xlabel(r'\textbf{time (s)}')
plt.ylabel('\\textit{Velocity (\u00B0/sec)}', fontsize=16)
plt.title(r'\TeX\ is Number $\displaystyle\sum_{n=1}^\infty'r'\frac{-e^{i\pi}}{2^n}$!', fontsize=16, color='r')
plt.grid(True)
plt.show()

Postscript 选项

为了生成可以嵌入到新 LaTeX 文档中的 postscript 封装文件,matplotlib 的默认行为是提取输出,这会删除 LaTeX 使用的一些 postscript 操作符,这些操作符在 eps 文件中是非法的。 此步骤产生的结果对于一些用户可能是不可接受的,因为文本被粗略地光栅化并且被转换为位图,而不像标准 Postscript 那样是可缩放的,并且文本是不可搜索的。 一种解决方法是在你的rc设置中将ps.distiller.res设置为较高的值(可能为 6000),这将产生较大的文件,但可能看起来更好并能够合理缩放。 更好的解决方法需要 Poppler 或 Xpdf,可以通过将ps.usedistiller rc设置更改为xpdf来激活。 此替代方案产生 postscript 而不光栅化文本,因此它能够正确缩放,可以在 Adobe Illustrator 中编辑,并搜索pdf文档中的文本。

可能的问题

  • 在 Windows 上,可能需要修改PATH环境变量来包含 latex,dvipng 和 ghostscript 可执行文件的目录。详细信息请参阅环境变量和在 Windows 中设置环境变量。
  • 使用 MiKTeX 与 Computer Modern 字体,如果你得到奇怪的 *Agg 和 PNG 结果,访问MiKTeX/Options并更新你的格式文件。
  • 字体在屏幕上看起来糟糕。你可能正在运行 Mac OS,在 mac 上的老版本 dvipng 运行着一些有趣的事情。在你的matplotlibrc文件中设置text.dvipnghack:True
  • 在 Ubuntu 和 Gentoo 上,texlive 基本安装不附带 type1cm 包。你可能需要安装一些额外的包,来获得所有与其它 LaTeX 分发版捆绑的特性。
  • matplotlib 已经取得了一些进展,所以可以直接使用dvi文件进行文本布局。这允许 LaTeX 用于具有pdfsvg后端的文本布局,以及 *Agg 和 PS 后端。在将来,LaTeX 安装可能是唯一的外部依赖。

故障排除

  • 尝试删除.matplotlib/tex.cache目录。 如果你不知道.matplotlib在哪里,请参见 matplotlib 配置和缓存目录位置。
  • 确保 LaTeX,dvipng 和 ghostscript 都正常工作,并存在于你的PATH中。
  • 确保你想要做的事情在 LaTeX 文档中可实现,你的 LaTeX 语法是有效的,并且你正在使用原始字符串,如果必要,以避免意外的转义序列。
  • 邮件列表上报告的大多数问题已通过升级 Ghostscript 来清除。 如果可能的话,请尝试升级到最新版本,然后向列表报告问题。
  • text.latex.preamble rc设置不受官方支持。 此选项提供了大量的灵活性和导致问题的许多方法。 请在向邮件列表报告问题之前禁用此选项。
  • 如果仍需要帮助,请参阅获取帮助。

Matplotlib 中文用户指南 4.7 使用 LaTeX 渲染文本相关推荐

  1. Matplotlib 中文用户指南 2 安装

    安装 原文:Installing 译者:飞龙 协议:CC BY-NC-SA 4.0 有许多安装 matplotlib 的不同方法,最好的方法取决于你使用的操作系统,已经安装的内容以及如何使用它. 为了 ...

  2. Matplotlib 中文用户指南 4.6 编写数学表达式

    编写数学表达式 原文:Writing mathematical expressions 译者:飞龙 协议:CC BY-NC-SA 4.0 你可以在任何 matplotlib 文本字符串中使用子 TeX ...

  3. Matplotlib 中文用户指南 3.1 pyplot 教程

    pyplot 教程 原文:Pyplot tutorial 译者:飞龙 协议:CC BY-NC-SA 4.0 matplotlib.pyplot是一个命令风格函数的集合,使matplotlib的机制更像 ...

  4. Matplotlib 中文用户指南 4.8 XeLaTeX/LuaLaTeX 设置

    XeLaTeX/LuaLaTeX 设置 原文:Typesetting With XeLaTeX/LuaLaTeX 译者:飞龙 协议:CC BY-NC-SA 4.0 使用 pgf 后端,matplotl ...

  5. Matplotlib 中文用户指南 4.4 默认字体

    默认字体 原文:Text properties and layout 译者:飞龙 协议:CC BY-NC-SA 4.0 基本的默认字体由一系列rcParams参数控制: rcParam 用法 'fon ...

  6. Matplotlib 中文用户指南 3.9 路径效果指南

    路径效果指南 原文:Path effects guide 译者:飞龙 协议:CC BY-NC-SA 4.0 Matplotlib 的patheffects模块提供了一些功能,用于将多个绘制层次应用到任 ...

  7. Matplotlib 中文用户指南 3.6 图例指南

    图例指南 原文:Legend guide 译者:飞龙 协议:CC BY-NC-SA 4.0 此图例指南是legend()中可用文档的扩展 - 请在继续阅读本指南之前确保你熟悉该文档(见篇尾)的内容. ...

  8. Matplotlib 中文用户指南 5.1 指定颜色

    指定颜色 原文:Specifying Colors 译者:飞龙 协议:CC BY-NC-SA 4.0 在 matplotlib 的几乎所有地方,用户都可以指定颜色,它可以以如下形式提供: RGB 或者 ...

  9. Matplotlib 中文用户指南 4.5 标注

    标注 原文:Annotation 译者:飞龙 协议:CC BY-NC-SA 4.0 基本标注 使用text()会将文本放置在轴域的任意位置. 文本的一个常见用例是标注绘图的某些特征,而annotate ...

最新文章

  1. 在CentOS Linux上安装oracle11g之二 安装oracle11g
  2. MVC中使用Entity Framework 基于方法的查询学习笔记 (二)
  3. SQL中使用DISTINCT显示多个字段的方法(不使用DISTINCT了)
  4. sco linux crontab重启,crontab 详解
  5. 从现实抽象出类的步骤
  6. Flink SQL 实战:HBase 的结合应用
  7. git学习笔记-(15-远程跟踪分支)
  8. 余晨:我终于采访到了马斯克,他是个腼腆的钢铁侠
  9. U盘文件系统损坏恢复
  10. 在中关村创业大街Binggo这半年
  11. java刷票脚本_我来分享一段自己写的刷票脚本 Version 1.0
  12. TP5中的No input file specified
  13. 互联网日报 | 58到家正式改名“天鹅到家”;华为“服务日”活动宣布延长一年;特斯拉上线电池回收服务...
  14. 一元二次方程的解c语言,一元二次方程求解程序完整代码
  15. 体系结构笔记------动态调度中的Tomasulo算法
  16. python 回溯法 01背包问题_01背包问题(回溯法)python实现
  17. 机器学习作业之波士顿房价(boston)数据分析与绘图(注释我都写了这么多,我不信你还看不懂?)
  18. 高级Java程序员技术栈
  19. 人工智能有哪些好处???
  20. 优雅的点-2017网易校园招聘

热门文章

  1. (15)System Verilog结构体struct详解
  2. (2)FPGA面试技能提升篇(Perl脚本)
  3. Vivado时序报告名词解释
  4. 【蓝桥杯嵌入式】【STM32】6_ADC之LCD实时显示电压值
  5. 【STM32】按键---有关GPIO输入的那些事
  6. squid 的配置详解 (转)--SeriesI
  7. 内核中的UDP socket流程(5)——inet_create
  8. 滤波电容、去耦电容、旁路电容的作用
  9. java5新特性_5分钟了解Java 12 八大新特性
  10. ML、DL、CNN学习记录8