python使用MkDocs自动生成文档

python使用MkDocs自动生成文档

  • 前言
  • 使用MkDocs
    • 环境
    • 相关资料
    • 使用介绍
      • 项目结构
      • 配置文件
      • 注释生成文档的配置
      • 运行与构建
      • 部署
  • 实践的项目

前言

python代码注释风格有很多,比较主流的有 reStructuredText风格、numpy风格、Google风格。

自动生成文档的工具也有很多,常见的有:

  • Pydocs python环境自带,支持MarkDown,但功能比较简单;
  • Sphinx 非常流行,默认支持reStructuredText风格注释,若要支持MarkDown需要扩展插件支持;
  • MkDocs 优势是能够很好的支持MarkDown格式来组织文档,支持Google风格注释;

对于熟悉MarkDown语法的人来说,推荐使用MkDocs,使用起来很方便。

使用MkDocs

环境

  • python3.9
  • 安装依赖
mkdocs==1.6.0
mkdocstrings==0.25.1
mkdocstrings-python==1.10.3
mkdocs-autorefs==1.0.1
mkdocs-material==9.5.24
mkdocs-same-dir==0.1.3

相关资料

  • MkDocs 主要文档核心库
  • MkDocs配套的mkdocstrings 负责从代码中提取注释形成文档
    • yaml配置中,插件mkdocstrings的options配置可以好好查看文档说明;
    • mkdocs.yml配置是全局生效,在注释生成配置各个类中也可以单独配置;
  • Google 开源项目风格指南 – 中文版
  • mkdocs-autorefs 可以在文档中使用超链定位到其他位置
  • mkdocs-material 文档主题风格插件
    • Material for MkDocs 是效果最好且持续更新的;
    • 若不需要material风格,可以不需要该插件;
    • MkDocs 官方内置了两个主题 mkdocsreadthedocs
    • 当然mkdocs也支持自定义主题风格 (一般情况下无需自己定义,有开源插件支持);
  • mkdocs-same-dir 该插件可以解决访问项目根目录下README.md的问题 (mkdocs默认寻找docs目录下的MarkDown文件)

使用介绍

记得提前安装相关依赖。

项目结构

截取部分展示:

├── pykit_tools  # 源码目录
│   ├── __init__.py
├── docs
│   ├── CHANGELOG-1.x.md
│   ├── CONTRIBUTING.md
│   └── Reference.md
├── .readthedocs.yaml
├── mkdocs.yml
├── README.md
├── requirements_docs.txt

配置文件

mkdocs.yml MkDocs主配置文件

site_name: pykit-tools
repo_url: https://github.com/SkylerHu/pykit-tools
docs_dir: .# 配置主题
theme:name: readthedocs# name: materiallanguage: zh# 配置文档菜单
nav:- 首页: README.md- 使用(Usage): docs/Reference.md- Release Notes: docs/CHANGELOG-1.x.md- 贡献者指南: docs/CONTRIBUTING.md# 插件配置
plugins:- search  # 内置插件,在标题中添加了一个搜索栏,允许用户搜索您的文档- same-dir  # 插件mkdocs-same-dir- autorefs- mkdocstrings:default_handler: pythonhandlers:python:# 配置解析代码注释的路径paths: [pykit_tools]options:heading_level: 3  # 使用了三级菜单,在docs/Reference.md文档中会有体现show_root_heading: trueshow_symbol_type_heading: trueshow_source: falseselection:docstring_style: google

注释生成文档的配置

配置文件中 options 配置详见 mkdocstrings globallocal-options

示例配置docs/Reference.md (截取部分) , 其中:::是特定格式,配置类或者函数的python模块路径:

# 使用(Usage)## 装饰器
::: decorators.commonoptions:  # 会覆盖全局配置members:- handle_exception- time_record::: decorators.cacheoptions:members:- method_deco_cache- singleton_refresh_regular

运行与构建

执行 mkdocs serve 后可通过http://127.0.0.1:8000/访问;

执行 mkdocs build --clean 可以构建生成网站site目录,可以将site添加到.gitignore文件中;

site目录中的html、js等文件可用于自行部署成文档服务网站。

部署

免费开源的部署,一般有两个选择:

  • Github Pages
    • 发布到GitHub Pages的说明;
    • 限制:每个用户只能免费新建一个按照自己账号名称命名的pages;
  • readthedocs网站
    • 支持 SphinxMkDocs 两种方式的部署;
    • 相关配置说明;
    • 对开源项目文档免费使用;
    • 使用该种方式托管文档,必须使用readthedocs的主题;

本文使用了readthedocs网站托管,网站可以使用Github账号登录,即可同步github项目信息,便捷导入生成文档。

部署需要依赖配置文件.readthedocs.yaml, 内容示例如下:

version: 2# 构建文档需要的环境
build:os: ubuntu-22.04tools:python: "3.9"# 文档工具相关配置
mkdocs:configuration: mkdocs.yml# 安装依赖
python:install:- requirements: requirements_docs.txt  # 自己维护在项目中的依赖文件

具体导入步骤根据同步的GitHub项目列表,参考指引提示即可完成;
也可以参考文档 文件托管系统-ReadtheDocs 。

实践的项目

  • 代码地址:https://github.com/SkylerHu/pykit-tools
  • 文档地址:https://pykit-tools.readthedocs.io

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

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

相关文章

IO流(1)

定义:存取和读取数据的解决方案 作用:用于读写数据(本地文件、网络) 分类: 一种是:输出流和输入流。 一种是:字节流和字符流。 字节流 字节流——FileOutputStream(字节输出流&…

C++标准模板(STL)- 变参数函数

变参数函数 变参数函数是接收可变数量参数的函数(例如 std::printf )。 为声明变参数函数,要以省略号为最后的形参,例如 int printf(const char* format, ...); 。语法上的额外细节、自动参数转换及替用项见变参数。 为从函数…

L9110S电机控制模块

1.L9110s控制小车前进后退左右 接通VCC,GND 模块电源指示灯亮, 以下资料来源官方,但是仍需我们调制 (前进): L1A输入低电平,L1B输入高电平 R1A输入低电平,R1B输入高电平 &a…

智能优化算法 | Matlab实现DBO蜣螂优化算法

智能优化算法 | Matlab实现DBO蜣螂优化算法 文章目录 智能优化算法 | Matlab实现DBO蜣螂优化算法文章概述源码设计文章概述 智能优化算法 | Matlab实现DBO蜣螂优化算法 源码设计 % ----------------------------------------------------------------------------------------…

(函数)判断一句话中最长的单词(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>//声明函数&#xff1b; int aiphabetic(char); int longest(char[]);int main() {//初始化变量值&#xff1b;int i;char line[100] { 0 };//获取用户输入字符…

【HM】使用@Builder装饰器,顺便要知道@BuilderParam,且注意this的指向

Builder装饰器修饰的函数是自定义构造函数&#xff0c;可以定义组件内构造函数&#xff0c;也可以定义全局构造函数&#xff0c;提供给外部组件使用。 就是通过自定义构造函数&#xff0c;可以把build(){// UI元素} 构造函数内的UI部分&#xff0c;抽离出来封装成一个函数&…

Gradle命令打包 Execution failed for task ‘:app:compileDebugJavaWithJavac错误

Gradle命令打包的时候遇到的&#xff0c;Gradle的java版本不对导致的&#xff0c;用的17&#xff0c;换成11的就能正常打包了。

大模型管理工具Ollama搭建及整合springboot

目录 一、Ollama介绍 1.1 什么是Ollama 1.2 Ollama特点与优势 二、Ollama本地部署 2.1 版本选择 2.2 下载安装包 2.3 执行安装 2.4 Ollama常用命令 三、使用Ollama部署千问大模型 3.1 千问大模型介绍 3.2 部署过程 四、springboot接入Ollama 4.1 引入Ollama依赖 4…

树莓派LCD显示屏安装驱动详细教程

使用LCD显示屏有两种方式&#xff0c;1.如果你已安装好树莓派官方系统&#xff0c;需要单独安装驱动才可点亮显示屏。 2. 也可以直接烧录我们提供的系统 里面已含驱动程序。 一&#xff1a;连接方式 按照下图方式连接好LCD显示屏与树莓派主板 二&#xff1a;安装系统镜像&…

6个适合在家做的副业兼职,做得好的月入过万,适合上班族和宝妈

嘿&#xff0c;亲爱的朋友们&#xff01;是不是常常觉得钱包瘪瘪&#xff0c;却又因为种种原因无法外出兼职&#xff1f; 别急&#xff0c;我来为大家揭秘几个在家也能轻松赚钱的靠谱副业&#xff0c;让你足不出户也能月入过万&#xff0c;从此告别财务烦恼&#xff01; 副业一…

7岁男孩学什么编程好一些:探索儿童编程的四大领域与未来潜能

7岁男孩学什么编程好一些&#xff1a;探索儿童编程的四大领域与未来潜能 在数字化时代&#xff0c;编程已成为一项重要的技能。对于7岁的男孩来说&#xff0c;选择适合的编程学习内容至关重要。那么&#xff0c;究竟哪些编程课程更适合这个年龄段的孩子呢&#xff1f;本文将从…

1.5.3 基于Java配置方式使用Spring MVC

本实战教程主要介绍了如何使用Java配置方式来使用Spring MVC框架。相较于XML配置方式&#xff0c;Java配置方式提供了一种更为简洁和灵活的配置方法。 项目创建与配置 创建一个Jakarta EE项目&#xff0c;并设置项目名称和位置。选择Jakarta EE 10版本&#xff0c;不添加依赖&a…

python中的预编译正则表达式

预编译正则表达式指的是使用Python的re模块中的re.compile()函数提前将正则表达式的字符串形式编译成一个正则表达式对象。这样&#xff0c;当你需要在多个地方或多次使用同一个正则表达式时&#xff0c;你可以重用这个编译后的对象&#xff0c;而不是在每次使用时重新编译表达…

404.左叶子之和

计算给定二叉树的所有左叶子之和。 示例&#xff1a; 思路&#xff1a; 通过父节点来判断七子节点是不是我们要收集的元素。因为如果遍历到孩子节点&#xff0c;我们无法判断它是左孩子还是右孩子。 后序遍历&#xff0c;左右中。 判断当前节点是不是左叶子是无法判断的&…

Turtle中circle用法详解

在Python的Turtle图形库中&#xff0c;circle方法是一个非常灵活的工具&#xff0c;它允许我们以简单的方式绘制圆或圆的一部分。本文将深入探讨circle方法&#xff0c;特别关注radius和extent参数的用途及其正负值的意义。 一、circle方法概览 首先&#xff0c;让我们了解一…

271 基于matlab的可调Q因子小波变换故障诊断

基于matlab的可调Q因子小波变换故障诊断&#xff0c;可用在轴承、齿轮、活塞等故障诊断中&#xff0c;程序中包含了原始TQWT工具箱和轴承振动信号信号的谱包络的求取。通过仿真数据、实际轴承数据说明了方法的效果。程序已调通&#xff0c;可直接运行。 271 可调Q因子小波变换 …

JavaScript第五讲:事件,条件循环语句,错误处理

前言 在编程的世界里&#xff0c;事件、条件和循环语句、以及错误处理是构建任何复杂程序或应用的基石。无论是开发一个简单的网页交互&#xff0c;还是构建一个庞大的企业级系统&#xff0c;这些基础概念都扮演着至关重要的角色。今天星途将通过这篇文章&#xff0c;分别深入…

java中判断String类型为空和null的方法

1.判断一个String类型的变量是否为空&#xff08;即长度为0&#xff09;或者为null 在Java中&#xff0c;判断一个String类型的变量是否为空&#xff08;即长度为0&#xff09;或者为null&#xff0c;通常需要使用两个条件语句来进行检查。这是因为null表示变量没有引用任何对…

01PCB设计概述

PCB设计概述 EDA electronic design automatic 电子设计自动化&#xff08;利用计算机来实现电子设计&#xff09; 分为 &#xff1a; 微电子&#xff08;芯片设计&#xff09;、硬件板卡&#xff08;PCB设计&#xff09; 画原理图、画PCB布线 要会绘制原理图库、和封装图库 元…

计算机组成原理06:浮点数运算

浮点数加减运算 之前我们提到过&#xff0c;浮点数具有特定的表示形式。因此&#xff0c;在进行浮点数的加减运算之前&#xff0c;需要统一浮点数的表达方式。这里我们主要对浮点数表示中的尾数M进行处理&#xff0c;要求0≤M<1&#xff0c;统一格式如下&#xff1a; 正数…