如何使用 Emacs 创建 LaTeX 文档

本教程将引导您使用 GNU Emacs,通过强大的开源排版系统 LaTeX 创建文档。
277 位读者喜欢这篇文章。
document sending

Opensource.com

在他的优秀文章《LaTeX 文档创建入门》中,作者 Aaron Cocker 介绍了 LaTeX 排版系统,并解释了如何使用 TeXstudio 创建 LaTeX 文档。他还列出了一些用户在创建 LaTeX 文档时觉得有用的 LaTeX 编辑器。

我对 Greg Pittman 对这篇文章的评论引起了我的注意:“当你刚开始使用 LaTeX 时,它似乎需要大量的输入......”。这是真的。LaTeX 涉及大量的输入和调试,如果你错过了一个像感叹号这样的特殊字符,这可能会让许多用户,尤其是初学者感到沮丧。在本文中,我将向您介绍 GNU Emacs,并描述如何使用它来创建 LaTeX 文档。

创建您的第一个文档

通过输入以下命令启动 Emacs

emacs -q --no-splash helloworld.org

-q 标志确保不会加载 Emacs 初始化文件。--no-splash-screen 标志阻止启动画面,以确保只打开一个窗口,其中包含文件 helloworld.org

Emacs startup screen

GNU Emacs 在缓冲区窗口中打开 helloworld.org 文件。

让我们以 Emacs 的方式添加一些 LaTeX 标头:转到菜单栏中的Org,然后选择 Export/Publish

template_flow.png

如何插入默认模板。

在下一个窗口中,Emacs 提供导出或插入模板的选项。通过输入 # ([#] 插入模板) 插入模板。这将把光标移动到迷你缓冲区,提示符显示 Options category:。此时您可能不知道类别名称;按 Tab 键查看可能的补全。键入“default”并按 Enter 键。将插入以下内容

#+TITLE: helloworld
#+DATE: <2018-03-12 Mon>
#+AUTHOR:
#+EMAIL: makerpm@nubia
#+OPTIONS: ':nil *:t -:t ::t <:t H:3 \n:nil ^:t arch:headline
#+OPTIONS: author:t c:nil creator:comment d:(not "LOGBOOK") date:t
#+OPTIONS: e:t email:nil f:t inline:t num:t p:nil pri:nil stat:t
#+OPTIONS: tags:t tasks:t tex:t timestamp:t toc:t todo:t |:t
#+CREATOR: Emacs 25.3.1 (Org mode 8.2.10)
#+DESCRIPTION:
#+EXCLUDE_TAGS: noexport
#+KEYWORDS:
#+LANGUAGE: en
#+SELECT_TAGS: export

根据您的意愿更改标题、日期、作者和电子邮件。我的看起来像这样

#+TITLE: Hello World! My first LaTeX document
#+DATE: \today
#+AUTHOR: Sachin Patil
#+EMAIL: psachin@redhat.com

我们暂时不想创建目录,因此将 toc 的值从 t 更改为 nil 内联,如下所示

#+OPTIONS: tags:t tasks:t tex:t timestamp:t toc:nil todo:t |:t

让我们添加一个章节和段落。章节以星号 (*) 开头。我们将从 Aaron 的帖子中复制一些段落的内容(来自 Lipsum Lorem Ipsum 生成器

* Introduction

  \paragraph{}
  Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras lorem
  nisi, tincidunt tempus sem nec, elementum feugiat ipsum. Nulla in
  diam libero. Nunc tristique ex a nibh egestas sollicitudin.

  \paragraph{}
  Mauris efficitur vitae ex id egestas. Vestibulum ligula felis,
  pulvinar a posuere id, luctus vitae leo. Sed ac imperdiet orci, non
  elementum leo. Nullam molestie congue placerat. Phasellus tempor et
  libero maximus commodo.

helloworld_file.png

Helloworld.org 文件

内容就位后,我们将内容导出为 PDF。再次从 Org 菜单中选择 Export/Publish,但这次,键入 l (导出为 LaTeX),然后键入 o (作为 PDF 文件并打开)。这不仅会打开 PDF 文件供您查看,还会将文件另存为 helloworld.pdf,与 helloworld.org 在同一路径中。

org_to_pdf.png

将 helloworld.org 导出为 helloworld.pdf

org_and_pdf_file.png

在底部打开的 helloworld.pdf 文件

您也可以通过按 Alt + x,然后键入“org-latex-export-to-pdf”将 org 导出为 PDF。使用 Tab 键自动完成。

Emacs 还创建了 helloworld.tex 文件,以便您可以控制内容。

org_tex_pdf.png

Emacs 在三个不同的窗口中打开 LaTeX、org 和 PDF 文件

您可以使用以下命令将 .tex 文件编译为 .pdf

pdflatex helloworld.tex

您还可以将 .org 文件导出为 HTML 或简单的文本文件。我喜欢 .org 文件的原因是它们可以推送到 GitHub,在那里它们像任何其他 markdown 格式一样呈现。

创建 LaTeX Beamer 演示文稿

让我们更进一步,使用同一个文件创建 LaTeX Beamer 演示文稿,只需进行一些修改,如下所示

#+TITLE: LaTeX Beamer presentation
#+DATE: \today
#+AUTHOR: Sachin Patil
#+EMAIL: psachin@redhat.com
#+OPTIONS: ':nil *:t -:t ::t <:t H:3 \n:nil ^:t arch:headline
#+OPTIONS: author:t c:nil creator:comment d:(not "LOGBOOK") date:t
#+OPTIONS: e:t email:nil f:t inline:t num:t p:nil pri:nil stat:t
#+OPTIONS: tags:t tasks:t tex:t timestamp:t toc:nil todo:t |:t
#+CREATOR: Emacs 25.3.1 (Org mode 8.2.10)
#+DESCRIPTION:
#+EXCLUDE_TAGS: noexport
#+KEYWORDS:
#+LANGUAGE: en
#+SELECT_TAGS: export
#+LATEX_CLASS: beamer
#+BEAMER_THEME: Frankfurt
#+BEAMER_INNER_THEME: rounded


* Introduction
*** Programming
    - Python
    - Ruby

*** Paragraph one

    Lorem ipsum dolor sit amet, consectetur adipiscing
    elit. Cras lorem nisi, tincidunt tempus sem nec, elementum feugiat
    ipsum. Nulla in diam libero. Nunc tristique ex a nibh egestas
    sollicitudin.

*** Paragraph two

    Mauris efficitur vitae ex id egestas. Vestibulum
    ligula felis, pulvinar a posuere id, luctus vitae leo. Sed ac
    imperdiet orci, non elementum leo. Nullam molestie congue
    placerat. Phasellus tempor et libero maximus commodo.

* Thanks
*** Links
    - Link one
    - Link two

我们在标题中添加了三行

#+LATEX_CLASS: beamer
#+BEAMER_THEME: Frankfurt
#+BEAMER_INNER_THEME: rounded

要导出为 PDF,请按 Alt + x 并键入“org-beamer-export-to-pdf”。

latex_beamer_presentation.png

使用 Emacs 和 Org 模式创建的 Latex Beamer 演示文稿

我希望您喜欢使用 Emacs 创建此 LaTeX 和 Beamer 文档(请注意,使用键盘快捷键比鼠标更快)。Emacs Org-mode 提供的功能远不止我在这篇文章中可以介绍的;您可以在 orgmode.org 上了解更多信息。

标签
psachin
Sachin 热衷于自由和开源软件。他是 GNU Emacs 的狂热用户,喜欢谈论和撰写关于开源、GNU/Linux、Git 和 Python 的文章。他之前曾在 OpenStack、ManageIQ/CloudForms 和 Red Hat Insights 工作过。他还喜欢在业余时间探索 Swift 对象存储。可以通过 IRC 联系到他,用户名为 psachin@{Libera.Chat, Freenode, OFTC, gnome}。

14 条评论

这很有趣。在 Scribus,我们至少在概念上正在进行文档转换的工作。最初的想法是切换到 markdown,尽管当我查看 markdown 时,似乎主要的重点是从 markdown 到 HTML。Org-mode 似乎是一个有趣的替代方案。

感谢您的提及,我很高兴您喜欢这篇文章 :),这非常具有互惠性,因为具有讽刺意味的是,我最近几个月才开始使用 Emacs,并且一直在寻找在 Emacs 中正确使用 LaTeX 的方法。

这需要一段时间才能掌握。
我在导出时遇到了问题,它告诉我找不到 wrapfig.sty。
我如何确保拥有所有需要的文件?

顺便说一句,我添加了 texlive-wrapfig,它解决了这个问题,但我想我应该提出我遇到的问题,以供其他人参考。

回复 作者 Greg P

我又来了。现在我修复了 PDF 问题,我尝试导出为 HTML,它工作了,尽管 \paragraph{} 出现在网页上。此外,还创建了这个验证链接(失败了),但我不知道它是从哪里来的。

嗨 Greg,您可能想要使用 html 模板而不是默认模板导出为 HTML。不要使用“default”类别,而使用“html”类别,这应该可以解决问题。

关于 \paragraph 和 \today,这些对 html 导出无效(它们是 LaTeX 标签)。

以下是我用于 html 导出的内容

```
#+TITLE: Hello World! 我的第一个 LaTeX 文档
#+OPTIONS: html-link-use-abs-url:nil html-postamble:auto
#+OPTIONS: html-preamble:t html-scripts:t html-style:t
#+OPTIONS: html5-fancy:nil tex:t
#+CREATOR: Emacs 25.3.1 (Org 模式 8.2.10)
#+HTML_CONTAINER: div
#+HTML_DOCTYPE: xhtml-strict
#+HTML_HEAD
#+HTML_HEAD_EXTRA
#+HTML_LINK_HOME
#+HTML_LINK_UP
#+HTML_MATHJAX
#+INFOJS_OPT
#+LATEX_HEADER
#+OPTIONS: tags:t tasks:t tex:t timestamp:t toc:nil todo:t |:t

* 简介

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras lorem
nisi, tincidunt tempus sem nec, elementum feugiat ipsum. Nulla in
diam libero. Nunc tristique ex a nibh egestas sollicitudin.

Mauris efficitur vitae ex id egestas. Vestibulum ligula felis,
pulvinar a posuere id, luctus vitae leo. Sed ac imperdiet orci, non
elementum leo. Nullam molestie congue placerat. Phasellus tempor et
libero maximus commodo。
```

回复 作者 Greg P

这几乎看起来像您需要创建一个通用的文本文档,然后在之后粘贴设置(?)。或者也许编写一个 Perl 或 Python 脚本来转换默认设置到 html(?)。如果我要使用这个,我可能不得不编写我自己的文档,因为我发现那里的文档要么冗长要么简洁——除非您想继续写这个....

回复 作者 Greg P

我应该提到,制作单独的文件来导出为 pdf 和 html 似乎是多余的,并且不符合 org-mode 的本质。我通常每个导出只有一个文件!

OP 添加段落的方式是不必要的,留下一个空行应该会自动完成 AFIK!。即使这样,如果您想添加仅在 latex 中导出的内联 latex 命令,也可以使用我记不住的选项,只需在 Google 上搜索“Latex export org mode”。

回复 作者 Greg P

正如我所说,当转换为 HTML 时,latex 标签“\today”不会按预期读取。简单地指定一个日期就可以解决问题。

添加“\paragraph”是因为内容是从 Aaron 的帖子中复制的(只是想演示“它有效”)

“...一个文件适用于所有情况”是最终情况,用户会随着时间的推移获得。这是一个介绍,我想保持简单。

回复 作者 Justin Kaipada (未验证)

知识共享许可协议本作品根据知识共享署名-相同方式共享 4.0 国际许可协议获得许可。
© 2025 open-source.net.cn. All rights reserved.