生成 Django 中文文档 PDF 版

文章目录

    • 背景
    • 克隆 Django 文档和翻译仓库
    • 配置 `conf.py`
    • 设置和同步翻译
      • 生成 `.pot` 文件
      • 运行 `sphinx-intl update`
      • 复制翻译文件
    • 构建 PDF
      • 生成 tex 文件
      • 安装 MikTeX
      • 生成 PDF
    • Sphinx 生成文档

背景

浏览看到一个帖子,有个评论说可以用 sphinx 构建一个 pdf,正好最近用到了 sphinx,于是试了下,最终构建了一个关于 Django 官方文档的中文版 PDF 文件。

在这里插入图片描述


克隆 Django 文档和翻译仓库

打开命令行,执行以下命令克隆仓库:

git clone https://github.com/django/django.git
git clone https://github.com/django/django-docs-translations.git

切换到需要的版本的分支

# django-docs-translations
git checkout stable/4.2.x
# django
git checkout stable/4.2.x

安装第三方库

pip install sphinx sphinx-rtd-theme sphinx-intl  # 用于安装 Sphinx 和多语言支持
pip install -U sphinx_rtd_theme recommonmark latexmk  # 用于生成 PDF 所需的依赖

配置 conf.py

django/docs/conf.py 中添加或修改以下配置来启用中文翻译:

# 设置语言
language = 'zh_CN'# 加入 PDF 输出格式
latex_engine = 'xelatex'
latex_elements = {"fontpkg": r"""\setmainfont{Symbola}""","preamble": r"""\usepackage{newunicodechar}\usepackage[UTF8]{ctex}\newunicodechar{π}{\ensuremath{\pi}}\newunicodechar{≤}{\ensuremath{\le}}\newunicodechar{≥}{\ensuremath{\ge}}\newunicodechar{♥}{\ensuremath{\heartsuit}}\newunicodechar{…}{\ensuremath{\ldots}}\usepackage{ctex}  % 中文支持\usepackage{fontspec}  % 字体支持\setmainfont{Times New Roman}  % 英文主字体\setsansfont{Arial}  % 英文无衬线字体\setmonofont{Courier New}  % 英文等宽字体\setCJKmainfont{SimSun}  % 中文字体""",
}# Sphinx theme,可以不改
html_theme = "sphinx_rtd_theme"

设置和同步翻译

进入 django/docs 目录,用 sphinx-intl 设置语言环境。在生成多语言支持的翻译文件时,Sphinx 首先需要生成 .pot 文件。

生成 .pot 文件

django/docs 目录中运行以下命令,会将所有可翻译的文本提取为 .pot 文件,并放在 _build/gettext 目录中。

sphinx-build -b gettext . _build/gettext

运行 sphinx-intl update

在生成 .pot 文件后,接着运行 sphinx-intl update 命令,这一步将根据 .pot 文件创建或更新 zh_CN 语言的 .po 文件,这里是在 doc 目录下创建了 locale/zh_CN\LC_MESSAGES,并生成了一些后缀是po的文件。

sphinx-intl update -p _build/gettext -l zh_CN

复制翻译文件

django-docs-translations/zh_Hans/LC_MESSAGES 下的 .po 文件复制到 django/docs/locale/zh_CN/LC_MESSAGES,替换掉相应的 .po 文件。


构建 PDF

生成 tex 文件

django/docs 目录中运行以下命令生成 tex 文件(这里是在windows命令行):

sphinx-intl build
make.bat latex

成功后,这会在 _build/latex 文件夹中生成一个 django.tex 文件。

安装 MikTeX

安装 MikTeX 或 TeX Live 作为 LaTeX 引擎,用于生成 PDF。

我尝试下载 MikTeX下载_latex文本编辑器最新64位版v21.8_3DM软件 (3dmgame.com),安装目录是 D:\Program Files\MiKTeX

生成 PDF

django\docs\_build\latex 目录下,执行生成 pdf:

cd _build/latex
"D:\Program Files\MiKTeX\miktex\bin\x64\lualatex" -interaction=nonstopmode django.tex# "D:\Program Files\MiKTeX\miktex\bin\x64\pdflatex" django.tex  # 有报错,没搞成
# "D:\Program Files\MiKTeX\miktex\bin\x64\xelatex" -interaction=nonstopmode django.tex  # 书签没有标题

最后生成了如下 pdf。期间试了好几个方法,不是编译报错,就是生成了空白的 pdf,或者生成的 pdf 没有书签。

在这里插入图片描述


Sphinx 生成文档

也能在本地生成文档。

sphinx-build -b html . _build/html -D html_theme=sphinx_rtd_theme

进入 docs/_build/html,通过浏览器打开 index.html,看到文档。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885878.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 每日一题 2024/11/4-2024/11/10

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 11/4 633. 平方数之和11/5 3222. 求出硬币游戏的赢家11/6 3254. 长度为 K 的子数组的能量值 I11/7 3255. 长度为 K 的子数组的能量值 II11/8 3235. 判断矩形的两个角落是否…

关于我、重生到500年前凭借C语言改变世界科技vlog.18——内存函数

文章目录 1. memcpy函数2. memmove函数3. memset函数4. memcmp函数希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力&#xff01; 内存函数是用于 操作内存块的一组函数&#xff0c;它们可以对内存进行复制、移动、设置和比较等操作。这些函数主要在 <str…

下划线命名json数组转java对象

/*** 将驼峰式命名的字符串转换为下划线方式* @param camelCase* @return*/ private static String toUnderlineCase(String camelCase) {return StrUtil.toUnderlineCase(camelCase); }/*** 下划线-赋值给-驼峰* @param source 源数据* @param target 目标数据*/ public stati…

【计算机网络】Socket编程接口

一、sockaddr结构体 二、Socket常见接口 1. socket() 2. bind() 3. recvfrom() 4. sendto() 5. listen() 6. accept() 三、基本转换函数 1. 与port有关的转换 2.与ip有关的转换 IP地址的表示有两种&#xff1a;点分十进制表示和整数表示 "192.168.1.100" …

ReactOS 4.2 OBJECT_TYPE_INITIALIZERj结构体的实现

Windows内核为新对象类型的定义提供了一个全局的OBJECT_TYPE_INITIALIZER 数据结构,作为需要填写和递交的“申请单”: OBJECT_TYPE_INITIALIZER // // Object Type Initialize for ObCreateObjectType // typedef struct _OBJECT_TYPE_INITIALIZER {USHORT Length;BOOLEAN Us…

SpringCloud篇(注册中心 - Nacos)

目录 一、Nacos安装指南 1. Windows安装 1.1. 下载安装包 1.2. 解压 1.3. 端口配置 1.4. 启动 1.5. 访问 2. Linux安装 2.1. 安装JDK 2.2. 上传安装包 2.3. 解压 2.4. 端口配置 2.5. 启动 3. Nacos的依赖 二、Nacos注册中心的入门使用 1. 认识和安装Nacos 2. 服…

链游系统定制化开发:引领游戏产业的新时代

在数字革命的浪潮中&#xff0c;链游&#xff08;区块链游戏&#xff09;作为一种新兴游戏形式&#xff0c;正重新定义游戏产业的发展方向。链游将区块链技术与传统游戏结合&#xff0c;使游戏体验更加公平透明&#xff0c;并赋予玩家真正的资产所有权。这一领域不仅为玩家带来…

TortoiseSVN提示服务器凭证检核错误:站点名称不符

电脑重装了系统&#xff0c;下载了新版本SVN软件&#xff0c;一切准备就绪&#xff0c;准备大干一场。 打开SVN&#xff0c;一遍一遍的提示【TortoiseSVN提示服务器凭证检核错误:站点名称不符】&#xff0c;一次次的让我接受&#xff0c;终于忍受不了了。 TortoiseSVN提示服务…

《传统视觉算法在视觉算法中的地位及应用场景

一、引言 在计算机视觉领域的发展历程中&#xff0c;传统视觉算法扮演了至关重要的角色。尽管近年来深度学习算法在视觉任务中取得了巨大的成功&#xff0c;但传统视觉算法依然具有不可替代的地位。传统视觉算法通常基于数学模型和手工设计的特征&#xff0c;具有计算效率高、…

docker构建jdk11

# 建立一个新的镜像文件&#xff0c;配置模板&#xff1a;新建立的镜像是以centos为基础模板 # 因为jdk必须运行在操作系统之上 FROM centos:7.9.2009# 作者名 MAINTAINER yuanhang# 创建一个新目录来存储jdk文件 RUN mkdir /usr/local/java#将jdk压缩文件复制到镜像中&#…

第四十二章 Vue中使用mutations修改Vuex仓库数据

目录 一、mutations修改仓库数据 1.1. 概述 1.2. mutations修改数据基本步骤 1.3. 完整代码 1.3.1. main.js 1.3.2. App.vue 1.3.3. index.js 1.3.4. Son1.vue 1.3.5. Son2.vue 二、mutations传参语法 2.1. mutations传参基本步骤 2.2. 完整代码 2.2.1. index.js …

六通道CAN集线器

六通道CAN集线器 --SG-CanHub-600 功能概述 SG_CanHub_600是一款具有六路通道的工业级智能 CAN数字隔离中继集线器。 SG_CanHub_600能够实现信号再生、延长通信距离、提高总线负载能力、匹配不同速 率 CAN网络&#xff0c;同时强大的 ID过滤功能可以极大降低 CAN总线负荷&a…

学校服务器连接pycharm配置2

上一个可能还是有点问题&#xff0c;因为实际在跑的时候读取的其实是本地的anaconda&#xff0c;这个重新整了一下流程 首先在学校服务器先激活自己创建的虚拟环境&#xff0c;这里就不截图了 然后在pycharm里面打开设置 选择这个python解释器 这里有添加解释器 选择SSH …

基于node一键发布到服务器的js脚本

基于node一键将打包后的前端文件发布到服务器指定目录的js脚本 需要使用node的2个包 npm install ssh2 scp2基于node进行ssh连接的控件 下面直接贴代码&#xff0c;已经在代码中加了注释 const { exec } require(child_process); const { Client } require(ssh2); const …

LeetCode面试经典150题|228.汇总区间

给定一个 无重复元素 的 有序 整数数组 nums 。 返回 恰好覆盖数组中所有数字 的 最小有序 区间范围列表 。也就是说&#xff0c;nums 的每个元素都恰好被某个区间范围所覆盖&#xff0c;并且不存在属于某个范围但不属于 nums 的数字 x 。 列表中的每个区间范围 [a,b] 应该按…

excel-VLOOKUP函数使用/XVLOOKUP使用

多个窗口同时编辑表格&#xff0c;方便对照操作 使用开始-视图-新建窗口 将战区信息表的三列数据匹配到成交数据表上 可以使用VLOOKUP函数 有4个参数&#xff08;必须要查找的值&#xff0c; 要查找的区域&#xff0c;要返回区域的第几列数据&#xff0c;一个可选参数查找匹…

boost::intrusive_ptr为什么叫做倾入指针

boost::intrusive_ptr的命名来源于其工作原理和设计目的。这个智能指针被称为“倾入指针”&#xff08;intrusive&#xff09;是因为它依赖于对象本身提供的功能来管理引用计数&#xff0c;而不是像std::shared_ptr和std::weak_ptr那样在指针内部自动管理引用计数。 具体来说&…

kafka和Flume的整合

目录 一、Kafka作为Source 【数据进入到kafka中&#xff0c;抽取出来】 1、在我的flume的conf文件夹下&#xff0c;有个myconf文件夹&#xff1a; 2、 创建一个flume脚本文件&#xff1a; kafka-memory-logger.conf 3、测试 二、kafka作为Sink 【数据从别的地方抽取到kafka里…

PCL 点云分割 欧式聚类算法分割

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1欧式聚类分割 2.1.2分割后的可视化 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接: PCL点云算法与项目实战案例汇总(长期更新) 一、概述 本文介…

【运维】如何在不同操作系统上获取计算机硬件信息

目录 引言一、Windows 操作系统1.1 获取 CPU 信息1.2 获取内存信息1.3 获取硬盘信息1.4 获取显卡信息1.5 获取显存信息 二、macOS 操作系统2.1 获取 CPU 信息2.2 获取内存信息2.3 获取硬盘信息2.4 获取显卡信息2.5 获取显存信息 三、Linux 操作系统3.1 获取 CPU 信息3.2 获取内…