Sphinx 如何制作 Windows .chm 帮助文档

chm 帮助文档

前言

对于一些人来说,sphinx 这个名词可能有些陌生。但是,你可能在某些地方见过上图中的这种文档。sphinx 是 python 的一个第三方库,用于构建文档,并且方便快速地将文档转换成各种类型。同时,还可以和 Read The Docs 网站搭配,实现文档推送和自动更新等功能。markdown 可能是很多人更加经常使用的标记语言,而 sphinx 使用的是另一种标记语言:reStructuredText

使用 sphinx 可以生成本机上可以阅读的 html 文档。但是有时候文档编写到一定程度后,想分享给他人,可以考虑将文档打包成单机的 .chm 文档。本文将介绍这一部分。

写作目的

如何从 Sphinx 基础文件中构建生成出单机版的 Windows 帮助文件。

本文不包括:Sphinx 文档基础文件的构建(......),可以自己通过搜索引擎查找相关介使用绍。附上上图的 Read The Docs 链接:Sphinx 学习笔记

当你用过 sphinx 或者想自己构建一些类似上图中的文档时,本文或许值得一看。

正文

sphinx 文件结构

从此部分开始说明。

在当前路径下打开 console 窗口,运行

make htmlhelp

可以在上面的 build 文件夹中看见生成的 htmlhelp 的基础文件。

htmlhelp 基础文件

而将这些基础文件打包生成一份 .chm 文档,需要用到 Microsoft 的 HTML Help Workshop 软件,这个软件在微软官网上的链接不知为何挂掉了。这里有讨论(HTMLHelp Workshop - download for CHM compiler installation failed),也有人给出 Internet Archive 的储存链接。单纯复制一个下载地址,如果觉得不安全,请到上述讨论中找到他给的地址进行下载。

HTML Help Workshop

使用该软件打开上面生成的 .hhp 文件,不能直接将这个文件拖进去。

打开配置文件

按钮1: 你可以在这个按钮里面看到 button 选项卡,可以控制 .chm 文件最上方的按钮,比如增加刷新按钮。

按钮2: 保存所有文件,编译生成文件。

另外的其他配置可以自行尝试更改。确定都更改完成以后,点击按钮2就可以了。

结果

可以看到已经生成了我们想要的文件。一般到这一步就算完成了。
(注:目标文件打开状态下是无法生成的,这一点需要注意。)


这一步完成后,你可能发现有一些问题。比如点击 .chm 文件的字体按钮,字体无法改变。

通过尝试,我发现是和使用的 Sphinx 主题有关系。有部分主题的字体是写死的,正常情况下无法改变大小。比如写了

font-size: 15px;
font-size: 1em;

这种。这部分都在上面图片中的 _static 文件夹中都可以找到。

既然知道问题所在,那么修复起来也很简单了。我自己是写了一个脚本,直接删除掉该文件夹中每个 .css 文件中包含有类似上面将字体写死的代码行就可以了(将脚本做成命令行形式,后续需要的时候将目标路径拖进去跑一下就行)。删除掉之后重新点击按钮2 再生成一个新的文档,这个新的文档就能正常使用字体的扩大和缩小。

顺便将脚本也放在这里吧。

import argparse
import os
import re


parser = argparse.ArgumentParser(
    description='remove font size in css file'
)
parser.add_argument('path', help='css directory path')
args = parser.parse_args()
path = os.path.abspath(args.path)
if not os.path.exists(path):
    raise SystemExit(f'Path not exists: [{path}]')
for root, dirs, files in os.walk(path):
    for file in files:
        if not file.endswith('.css'):
            continue
        filepath = os.path.join(root, file)
        with open(filepath, 'r', encoding='utf-8')as fl:
            data = fl.read()
        data, n = re.subn(r'[ ]+font-size: .*?(?:px|em);\n?', '', data)
        if n == 0:
            continue
        with open(filepath, 'w', encoding='utf-8')as fl:
            fl.write(data)
        flag = 'part' if n == 1 else 'parts'
        print(f'[{filepath}] {n} {flag} changed!')

将上面的代码保存到文件 removeFontSize.py 里面,使用方式就是:
在脚本所在路径下打开 console 窗口,通过

python removeFontSize.py <path>

敲 python removeFontSize.py 加一个空格,然后把目标路径拖进去,Enter 就可以了。python 版本要 >=3.7

这些说明是不是太过于多此一举???


大概到这里才算大功告成吧。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容