2
0
mirror of https://github.com/LCTT/TranslateProject.git synced 2025-01-22 23:00:57 +08:00
TranslateProject/published/202208/20220810 Create beautiful PDFs in LaTeX.md

234 lines
10 KiB
Markdown
Raw Normal View History

2022-08-18 21:38:09 +08:00
[#]: subject: "Create beautiful PDFs in LaTeX"
[#]: via: "https://opensource.com/article/22/8/pdf-latex"
[#]: author: "Jim Hall https://opensource.com/users/jim-hall"
[#]: collector: "lkxed"
[#]: translator: "Donkey-Hao"
[#]: reviewer: "wxy"
[#]: publisher: "wxy"
[#]: url: "https://linux.cn/article-14957-1.html"
2022-08-18 21:38:09 +08:00
使用 LaTeX 创建优美的 PDF 文件
======
![](https://img.linux.net.cn/data/attachment/album/202208/23/120339s9ek65lo8cce5jj4.jpg)
2022-08-18 21:38:09 +08:00
> 使用 LaTeX 标记语言来撰写文档。
LaTeX 文件准备系统有一段有趣的历史。在 1968 年,程序员 Don Knuth 用一种老式印刷排版方式,撰写了他的第一本书《<ruby>计算机程序设计艺术<rt>The Art of Computer Programming</rt></ruby>》。当他在 1976 年出版第二版时,出版商已经转向现代照相排版技术。
2022-08-18 21:38:09 +08:00
Knuth 对新版本的外观不满意。他从程序员的角度解决问题决定创建他自己的文字处理系统这样以后他出版的书就可以以相同格式排版拥有相同的外观。因此Don Knuth 在 1978 年编写了第一版 TeX 。
几年后Leslie Lamport 创建了一组宏定义以便作者更容易编写复杂文档。Lamport 的宏定义扩展,即 LaTeX有效地扩展了 TeX 能够轻松创建各种文档。例如,许多学术组织使用 LaTeX 出版期刊和论文集。
2022-08-18 21:38:09 +08:00
### 使用 LaTeX 编写文档
通过写一些短文就可以很容易掌握 LaTeX 基础。让我们从 [Opensource.com][4] 介绍页面借用一下内容,创建一个示例:
2022-08-18 21:38:09 +08:00
```
$ cat about.tex
\documentclass{article}
\begin{document}
Opensource.com is a premier, daily publication focused on
open source and Linux tutorials, stories, and resources.
We're a diverse and inviting group, made up of staff
editors, Correspondents, contributors, and readers. We
value differences in skills, talents, backgrounds, and
experiences. There are a few different ways to get involved
as a reader or a writer.
\end{document}
```
类似其他文档格式程序, LaTeX 会将单词汇集起来,填充成段落 。这意味着你可以在段落中间添加新文本,而不用担心最终文档的段落参差不齐。只要你不在段落中添加空行, LaTeX 就会创建完全对齐的段落。当它找到一个空行时, LaTeX 会开启一个新段落。
2022-08-18 21:38:09 +08:00
LaTeX 需要一些定义文档的控制语句。任何 LaTeX 文档应当以“文档类别”声明开始。LaTeX 支持多种文档,包括书信、书籍和文章。例如,我使用 `\documentclass{article}` 设置类别为 “文章” 。
2022-08-18 21:38:09 +08:00
使用 `\begin{document}``\end{document}` 声明来定义文本的开始和结束。如果你在 `\begin{document}` 前添加了文本,那么 LaTeX 会报错。在 `\end{document}` 之后的文本都会被忽略。
使用 LaTeX 的 `latex` 命令处理文档:
2022-08-18 21:38:09 +08:00
```
$ latex about.tex
This is pdfTeX, Version 3.141592653-2.6-1.40.22 (TeX Live 2021) (preloaded format=latex)
restricted \write18 enabled.
2022-08-18 21:38:09 +08:00
entering extended mode
(./about.tex
LaTeX2e <2020-10-01> patch level 4
(/usr/share/texlive/texmf-dist/tex/latex/base/article.cls
Document Class: article 2020/04/10 v1.4m Standard LaTeX document class
(/usr/share/texlive/texmf-dist/tex/latex/base/size10.clo))
(/usr/share/texlive/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)
No file about.aux.
[1] (./about.aux) )
Output written on about.dvi (1 page, 736 bytes).
Transcript written on about.log.
```
LaTeX 会输出许多文本,这样你就可以知道它在干什么。若你的文档包含错误, LaTeX 会报错并提示它可以做什么。大多数情况下,你可以在提示后输入 `exit` 来强制退出 LaTeX 。
2022-08-18 21:38:09 +08:00
如果用 LaTeX 成功生成一个文档,会生成一个带 `.dvi` 后缀的文件。`DVI` 表示 “<ruby>设备无关<rt>Device Independent</rt></ruby>”,因为你可以使用不同的工具来生成其他格式。例如, `dvipdf` 程序可以将 DVI 文件转换为 PDF 文件。
2022-08-18 21:38:09 +08:00
```
$ dvipdf about.dvi
```
![LaTeX output][5]
2022-08-23 12:07:49 +08:00
### 添加列表
2022-08-18 21:38:09 +08:00
LaTeX 支持两种列表:一种以数字开头的 “枚举” 列表,一种 “逐项” 或 “项目符号” 列表。在第二段后添加一个简短的枚举列表,列出人们可以参与 Opensource.com 的方式:
2022-08-18 21:38:09 +08:00
```
\begin{enumerate}
\item Be a writer
\item Be a reader
\end{enumerate}
```
与在文档定义中添加 `\begin``\end` 声明类似,你也需要在列表前后添加 `\begin``\end` 声明。在列表中,每个项目以 `\item` 命令开始。当你用 LaTeX 处理该文档并转换为 PDF 格式后,你会看到该列表为数字列表:
![LaTeX output][6]
你也可以在列表中嵌套列表。这是一个优雅的功能,如果你需要在列表中为每个条目添加选项。例如,你可以为想要在 Opensource.com 中成为作者的人们提供一些不同的资源。嵌入列表使用单独的 `\begin``\end` 声明。为了看起来方便,我在示例中添加了空行,但是 LaTeX 会忽略这些空行:
```
\begin{enumerate}
\item Be a writer
  \begin{itemize}
  \item Resources for writers
  \item Contributor Club
  \item Correspondent Program
  \end{itemize}
\item Be a reader
\end{enumerate}
```
作为嵌套列表,新列表嵌入在编号 1 的项目中,因为你在原先的 `\item` 声明之间添加了列表。你可以通过在 `\end{enumerate}` 语句前添加新列表,作为编号 2 项目的嵌套列表。
![LaTeX output][7]
### 章节和小节
你可以将冗长文章分成多个章节,这样更易于阅读。使用 `\section{...}` 语句在大括号内添加章节标题。例如,你可以在文档顶部添加一个标题为 “About Opensource.com” 的新章节:
2022-08-18 21:38:09 +08:00
```
$ head about.tex
\documentclass{article}
\begin{document}
\section{About Opensource.com}
Opensource.com is a premier, daily publication focused on
open source and Linux tutorials, stories, and resources.
We're a diverse and inviting group, made up of staff
editors, Correspondents, contributors, and readers. We
```
`article` 文档类会在每个主要章节添加编号,并使字体变大来突出显示。
2022-08-18 21:38:09 +08:00
![LaTeX output][8]
你可以使用 `\subsection{...}` 命令来组织文档。就像 `\section{...}` 命令一样,在大括号中输入副标题名称。
2022-08-18 21:38:09 +08:00
```
$ head about.tex
\documentclass{article}
\begin{document}
\section{About Opensource.com}
Opensource.com is a premier, daily publication focused on
open source and Linux tutorials, stories, and resources.
\subsection{Welcome to the Opensource.com community}
```
![LaTeX output][9]
### 标题和作者
用于出版的科学类的文章需要标题、作者以及发表日期。LaTeX 提供了通过插入命令的方式来添加这些信息,然后使用单独的 `\maketitle` 命令生成文章的标题。
2022-08-18 21:38:09 +08:00
将 “About Us” 作为文章标题,作者为 “Opensource.com Editors”发表日期为 “July 10, 2022” 。你必须在 `\begin{document}` 之后,文章内容前插入这些内容。
2022-08-18 21:38:09 +08:00
```
\title{About Us}
\author{Opensource.com Editors}
\date{July 10, 2022}
\maketitle
```
当你在生成文档时LaTeX 会将标题、作者和日期添加到文章的顶部:
![LaTeX output][10]
### 着重强调
科学和其他技术类文章通常会突出术语和短语。 LaTeX 提供了几种可以在技术文档中使用的字体效果,包括强调文本(通常以斜体显示)、粗体文本和<ruby>小型大写字母<rt>small caps</rt></ruby>
2022-08-18 21:38:09 +08:00
将短语“staff editors, Correspondents, contributors, and readers”放在斜体文本中并将特定词“reader”和“writer”放在段落后面的强调文本中。你也可以将“skills, talents, backgrounds, and experiences”加粗。虽然这不是正确的样式设置方式但你可以使用小型大写字母来键入 “Linux” 。
2022-08-18 21:38:09 +08:00
```
$ head -20 about.tex
\documentclass{article}
\begin{document}
\title{About Us}
\author{Opensource.com Editors}
\date{July 10, 2022}
\maketitle
\section{About Opensource.com}
Opensource.com is a premier, daily publication focused on
open source and \textsc{Linux} tutorials, stories, and resources.
\subsection{Welcome to the Opensource.com community}
We're a diverse and inviting group, made up of \textit{staff
editors, Correspondents, contributors, and readers}. We
value differences in \textbf{skills, talents, backgrounds, and
experiences}. There are a few different ways to get involved
as a \emph{reader} or a \emph{writer}.
```
该示例展示了不同样式的文本的应用方法。当你需要强调时,使用 `\emph{...}` 命令,将强调主题放在大括号内。要以斜体、粗体或小型大写字母显示文本,使用 `\text` 命令的变体:`\textit{...}` 用于斜体,`\textbf{...}` 用于粗体,以及 `\ textsc{...}` 用于小型大写字母。LaTeX 支持许多其他方式来设置文本样式,这些样式有助于你编写科学技术类文章。
![LaTeX output][11]
### 使用 LaTeX
我只是介绍了使用 LaTeX 撰写科学技术文章的几种方式。你也可以在 LaTeX 中添加脚注,进行数学公式和方程的排版,取决于你的需求。你也可以通过阅读 Opensource.com 中的文章 [《在 LaTeX 中创建文档的介绍》][12] ,了解使用 LaTeX 撰写科学技术文章的其他方式。
--------------------------------------------------------------------------------
via: https://opensource.com/article/22/8/pdf-latex
作者:[Jim Hall][a]
选题:[lkxed][b]
译者:[Donkey](https://github.com/Donkey-Hao)
校对:[wxy](https://github.com/wxy)
2022-08-18 21:38:09 +08:00
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://opensource.com/users/jim-hall
[b]: https://github.com/lkxed
[1]: https://opensource.com/sites/default/files/lead-images/coffee_tea_laptop_computer_work_desk.png
[2]: https://unsplash.com/@jonasleupe?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText
[3]: https://unsplash.com/s/photos/tea-cup-computer?utm_source=unsplash&utm_medium=referral&utm_content=creditCopyText
[4]: https://opensource.com/about
[5]: https://opensource.com/sites/default/files/2022-08/latex-output.jpg
[6]: https://opensource.com/sites/default/files/2022-08/latex-output-list.jpg
[7]: https://opensource.com/sites/default/files/2022-08/latex-output-list-2.jpg
[8]: https://opensource.com/sites/default/files/2022-08/latex-output-heading.jpg
[9]: https://opensource.com/sites/default/files/2022-08/latex-output-subheading.jpg
[10]: https://opensource.com/sites/default/files/2022-08/latex-output-about.jpg
[11]: https://opensource.com/sites/default/files/2022-08/latex-output-emphasis.jpg
[12]: https://opensource.com/article/17/6/introduction-latex