什么是Sphinx注释?

一、什么是Sphinx注释? Sphinx注释是Python文档字符串(docstring)的一种标准格式,主要用于:

  1. 生成专业级API文档(通过Sphinx工具)
  2. 提供IDE智能提示支持
  3. 作为代码内联文档

与普通注释(#)不同,Sphinx注释使用三重引号"""包裹,具有特定语法规则。

二、基本语法规则

  1. 模块级注释
python 复制代码
"""Module-level docstring.

This is a brief description of the module.
More detailed explanation goes here.
"""
  1. 类注释
python 复制代码
class MyClass:
    """Class-level docstring.

    Args:
        param1 (type): Description of param1
        param2 (type): Description of param2

    Attributes:
        attr1 (type): Description of attr1
    """
  1. 函数/方法注释
python 复制代码
def my_function(param1, param2):
    """Function-level docstring.

    Args:
        param1 (type): Description
        param2 (type): Description

    Returns:
        type: Description of return value

    Raises:
        ErrorType: When something bad happens
    """

三、核心字段说明

字段 用途 示例
Args 参数说明 param1 (int): The first parameter
Returns 返回值说明 bool: True if successful
Raises 可能抛出的异常 ValueError: If input is invalid
Attributes 类属性说明 name (str): The name of instance
Examples 使用示例 >>> obj = MyClass()
Note 重要说明 Note: This is critical for...
.. versionadded:: 版本标记 .. versionadded:: 1.2.0

四、两种主流风格

  1. Google风格(推荐)
python 复制代码
def add(a, b):
    """Add two numbers.

    Args:
        a (int or float): First number
        b (int or float): Second number

    Returns:
        int or float: Sum of a and b

    Example:
        >>> add(2, 3)
        5
    """
    return a + b
  1. NumPy风格
python 复制代码
def subtract(a, b):
    """Subtract two numbers.

    Parameters
    ----------
    a : int or float
        First number
    b : int or float
        Second number

    Returns
    -------
    int or float
        Result of a - b
    """
    return a - b

五、实际应用示例

python 复制代码
class MolecularDataset:
    """AM1 molecular dataset handler.

    Args:
        data_path (str): Path to .pkl file
        max_atoms (int, optional): Max atoms per molecule. Defaults to 64.
        shuffle (bool, optional): Whether to shuffle data. Defaults to True.

    Attributes:
        elements (ndarray): Atomic numbers array
        coordinates (ndarray): 3D coordinates array

    Example:
        >>> dataset = MolecularDataset('data.pkl')
        >>> len(dataset)
        100
    """

    def __init__(self, data_path, max_atoms=64, shuffle=True):
        """Initialize with data path and parameters."""
        self.data_path = data_path
        self.max_atoms = max_atoms
        self.shuffle = shuffle

    def load(self):
        """Load molecular data from file.

        Returns:
            bool: True if loaded successfully

        Raises:
            FileNotFoundError: If data file doesn't exist
        """
        if not os.path.exists(self.data_path):
            raise FileNotFoundError
        return True

六、生成文档的步骤

  1. 安装Sphinx:
bash 复制代码
pip install sphinx sphinx-rtd-theme
  1. 创建文档项目:
bash 复制代码
sphinx-quickstart docs
  1. 配置docs/source/conf.py
python 复制代码
extensions = [
    'sphinx.ext.autodoc',
    'sphinx.ext.napoleon'  # 支持Google/NumPy风格
]
  1. 编写.rst文件(如api.rst):
rst 复制代码
API Reference
=============

.. automodule:: your_module
   :members:
   :show-inheritance:
  1. 生成HTML文档:
bash 复制代码
cd docs
make html

生成的文档将位于docs/_build/html目录,支持: • 自动参数类型链接

• 交互式示例代码

• 版本变更追踪

• 跨模块引用

七、IDE支持情况

IDE 功能支持
PyCharm 自动补全、悬浮提示、文档快速导航
VS Code 通过Python插件支持基本文档显示
Jupyter 使用???查看文档
Spyder 对象检查器(Object Inspector)显示完整文档
相关推荐
IVEN_7 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang8 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮8 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling8 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮11 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽12 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽1 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers