python - 修改 Sphinx TOC 树

标签 python python-sphinx

我有一个 Sphinx 项目,其目录 (index.rst) 包括 :maxdepth: 2。问题是我想将 release 部分的深度减少到 1 ,这样它就不会在主目录中包含发行说明列表(该列表太长)。

似乎可以使用 doctree-resolved 事件处理程序修改 TOC 列表,但我不知道如何在事件处理程序中修改 TOC 树:

from sphinx import addnodes

def setup(app):
    def update_toctree(app, doctree, docname):
        if docname != 'index':
            return

        node = doctree.traverse(addnodes.toctree)[0]
        toc = app.env.resolve_toctree(docname, app.builder, node)

        # do something with "toc" here

    app.connect('doctree-resolved', update_toctree)

最佳答案

也许这不是一个理想的解决方案,但在同一页面上使用多个 toctree 条目之前我已经做过类似的事情,例如:

####################
Presto Documentation
####################

.. toctree::
    :maxdepth: 2

    overview
    installation

.. toctree::
    :maxdepth: 1

    release

这并不理想,因为大多数主题会在树之间添加额外的填充,但在我的情况下,这比为某些页面使用大量嵌套项目要好。

关于python - 修改 Sphinx TOC 树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33637299/

相关文章:

python - 使用 Sphinx 自动记录 Python 3

python - 在 sphinx 中自定义方法签名

python - "fails to import module"在 Ubuntu 18.04 上运行 sphinxcontrib-matlabdomain 的 test_data 示例时

python - 我在哪里可以找到有关带有 sphinx-doc 拿破仑扩展的 Google 风格文档字符串中支持的新语法的更多信息?

python - 如何为 strptime() 格式化 +xxxx

python - 如何在具有高度受限实例的 Python 中创建类

python - 如何在多索引 Pandas 数据框中获取随机样本?

python - 在 Windows 10 上安装 numba 和 llvmlite Python 失败

python - 修复matplotlib中散点图中的颜色

matlab - 将子文件夹中的文件添加到 sphinx 文档 (sphinxcontrib-matlabdomain)