脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

2022-11-22 10:31新能源阿布 Python

这篇文章主要介为大家绍了Sphinx生成python文档示例图文解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪

前言

Sphinx是一款支持多种编程语言的文档生成工具,在python项目开发过程中,可以帮助开发者根据需求生成相应的说明文档,拿今天我们就基于该开源工具进行一个入门的实践。

安装

pip3 install sphinx

环境准备

1. 安装python,pycharm编辑器的电脑

2. 创建相关的项目目录,如下图所示,我们可以创建document_generate_sphinx的项目文件夹,在下面分别创建doc和src文件夹,前者用来存放sphinx工具生成的相关文档和配置文件,后者用来存放自己的项目源码文件。

3. 在src文件夹下创建demo_one.py和demo_two.py文件,并写上简单的几个类和测试代码,在doc目录下运行sphinx-quickstart,一路默认配置下来会生成如下图所示存在于doc文件夹中的文件(这其中除了要配置自己的项目名称,版本号等内容外,其他均默认或者yes即可)

Sphinx生成python文档示例图文解析

3. 接下来,我们可以运行sphinx-apidoc -o ../doc ../src/ 命令将源码生成rst文件到doc的文件夹下,如下图

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

4. 到此,我们就可以尝试 在doc目录下 运行make html指令来生sphinx说明文档了,但是在这里发生了报错如下

Sphinx生成python文档示例图文解析

  从报错的内容来看分为两类,第一个是在提示我们没有发现automodule,第二个是发现modules.rst文件中没有toctree。

经过实践我们得到解决第一个问题需要在conf.py文件中添加上extensions = ["sphinx.ext.autodoc"]插件即可,解决第二个问题,需要在index.rst文件中添加上modules的文件路径,如下所示

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

5. 此时,我们再去运行make clean&make html指令,可以清除之前生成的文档,生成新的文档在build或者_build文件夹中,打开_build文件夹html文件夹中的index.html文件可以发现生成的文档如下图

Sphinx生成python文档示例图文解析

6. 在实际阅读开源库的说明文档过程中会发现,目前python的很多开源文档都是统一的蓝白交替的主题,为了让自己显得更专业,可以为其替换一下目前流行的主题,在替换主题前,需要安装一下主题库,并在conf.py文件中做一个主题配置。如下

  6.1 pip3 install sphinx_rtd_theme

  6.2 在conf.py文件中将 html_theme = "alabaster"更换如下图,再添加上html_theme_path

Sphinx生成python文档示例图文解析

7. 重新运行make clean&make html命令,生成的新文档说明如下

Sphinx生成python文档示例图文解析

8. 至此,完成了一个简单的两个程序代码的文档生成示例,但是在实际项目中,可能还设计到其他目录下文件的添加和变更,怎样把需要展示的文件展示到文档中?类如changelog的添加,其他文件的添加。

  比如,这里在doc目录下直接人为创建一个非py代码的说明文件,命名为changelog.rst,然后直接运行make clean&make html指令,得到了如下报错

Sphinx生成python文档示例图文解析

  从报错内容的提示来看,是因为changelog文件没有被放到toctree中,所以需要在index.rst文件中添加上changelog的目录,如下图所示

Sphinx生成python文档示例图文解析

9. 再次运行make clean&make html指令,编译顺利成功,但是发现打开文档目录中index后,显示特别丑,个人建议可以将其删掉,原图如下

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

10. 删除掉index.rst文件中红色部分,如下左图,然后再次编译生成新的文档,可以发现没有了索引模块,显得简单干净,如下右图所示。

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

11. 如果在开发过程中更改了源代码需要展示的文件,需要重新运行生成rst文件的指令 sphinx-apidoc -o ../doc ../src/

  比如,为了示范,我们将原来src文件中的demo_one.py 和 demo_two.py分别更名成 animal_attack.py和dog_aonstan.py文件,并重新写了一些代码,那么就需要重新运行上述指令并删除原来的rst文件并更改modules.rst文件中的module名称,如下图

Sphinx生成python文档示例图文解析

  再次运行make clean&make html指令,发现编译成功,文档也更新了相关模块和内容,另外会有人说,如果需要在文档中展示的函数能够链接到源码,需要怎么做,这里很简单。

12. 文档展示函数链接源码,在conf.py文件中extensions中添加"sphinx.ext.viewcode"模块 重新生成文档如下

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

Sphinx生成python文档示例图文解析

 

结 语

  至此,Sphinx文档生成的简单入门示例就完成啦,如果需要更深入的研究和探讨,大家可以参考sphinx的官方文档。

以上就是Sphinx生成python文档示例图文解析的详细内容,更多关于Sphinx生成python文档的资料请关注服务器之家其它相关文章!

原文链接:https://www.cnblogs.com/nio123/p/16102230.html

延伸 · 阅读

精彩推荐
  • Python8种常用的Python工具

    8种常用的Python工具

    这篇文章主要介绍了8种常用的Python工具,帮助大家更好的学习Python,感兴趣的朋友可以了解下...

    小小科10062020-08-05
  • PythonPython实现删除windows下的长路径文件

    Python实现删除windows下的长路径文件

    这篇文章主要为大家详细介绍一下如何利用Python语言实现删除windows下的长路径文件功能,文中的示例代码讲解详细,具有一定参考借鉴价值,感兴趣的可以...

    Python进阶者9842022-07-21
  • Pythonpython函数中return后的语句一定不会执行吗?

    python函数中return后的语句一定不会执行吗?

    这篇文章主要给大家详细分析讲解了关于python函数中return语句后的语句是否一定不会执行的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价...

    快递小可7332020-11-24
  • Python对Python3使运行暂停的方法详解

    对Python3使运行暂停的方法详解

    今天小编就为大家分享一篇对Python3使运行暂停的方法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    ZonarZmz5262021-05-29
  • Pythonpython调用fortran模块

    python调用fortran模块

    本文给大家介绍的是在Python中调用fortran代码,主要是用到了f2py这个程序,十分的实用,有需要的小伙伴可以参考下 ...

    Python教程网6192020-08-18
  • PythonPython利用operator模块实现对象的多级排序详解

    Python利用operator模块实现对象的多级排序详解

    python中的operator模块提供了一系列的函数操作。下面这篇文章主要给大家介绍了在Python中利用operator模块实现对象的多级排序的相关资料,需要的朋友可以参...

    kongxx4642020-10-08
  • Python聊聊python里如何用Borg pattern实现的单例模式

    聊聊python里如何用Borg pattern实现的单例模式

    这篇文章主要介绍了聊聊python里如何用Borg pattern实现的单例模式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    kid_learning7832021-07-02
  • Python利用Python实现外观数列求解

    利用Python实现外观数列求解

    这篇文章主要介绍了利用Python实现外观数列求解,文章利用举例说明文章的主题内容,具有一定的参考价值,需要的小伙伴乐意参考一下...

    赵卓不凡4142022-11-15