代码文档

news/2024/5/8 9:24:32/文章来源:https://blog.csdn.net/hengfanz/article/details/128128554

为您的团队和您未来的自己代码文档。

Intuition

代码告诉你_怎么_做,注释告诉你_为什么_。——杰夫·阿特伍德

可以通过代码文档来进一步组织代码,让其他人(以及未来的自己)更容易轻松地导航和扩展它。在完成编写代码库的那一刻就最了解代码库,但幸运的是,记录它将使能够快速回到熟悉的心态。文档对开发人员来说可能意味着很多不同的东西,所以让定义最常见的组件:

  • comments:关于为什么存在一段代码的简短描述。
  • typing:函数输入和输出数据类型的规范,提供与函数消耗和产生的内容有关的信息。
  • docstrings:对描述整体效用、参数、返回等的函数和类的有意义的描述。
  • docs:呈现的网页,总结了所有的功能、类、工作流程、示例等。

目前,将在本地生成文档,但请务必查看应用程序的自动生成文档页面。每次对代码库进行更改时,将在CI/CD课程中学习如何自动创建文档并使其保持最新。

代码协作

您目前如何与团队中的其他人共享您的代码?有什么可以改进的?

Typing

对代码尽可能明确是很重要的。已经讨论过为变量、函数等选择显式名称,但可以显式的另一种方法是为函数的输入和输出定义类型。

到目前为止,函数看起来像这样:

def some_function(a, b):
    return c

但是可以使用打字来合并更多信息:

from typing import List
def some_function(a: List, b: int = 0) -> np.ndarray:
    return c

在这里定义了:

  • 输入参数a是一个列表
  • 输入参数b是一个整数,默认值为0
  • 输出参数c是一个 NumPy 数组

可以使用许多其他数据类型,包括ListSetDict、和更多Tuple,以及包含的类型,例如,等。您还可以使用安装的包(例如)甚至自己定义的包中的类型类(例如)。Sequenceint``float``np.ndarray``LabelEncoder

从 Python 3.9+ 开始,内置了常用类型,因此不再需要导入它们from typing import List, Set, Dict, Tuple, Sequence

文档字符串

可以通过添加文档字符串来描述整体实用程序、参数、返回、异常等,从而使代码更加明确。让看一个例子:

from typing import List
def some_function(a: List, b: int = 0) -> np.ndarray:
    """Function description.

    ```python
    c = some_function(a=[], b=0)
    print (c)
    ```
    <pre>
    [[1 2]
     [3 4]]
    </pre>

    Args:
        a (List): description of `a`.
        b (int, optional): description of `b`. Defaults to 0.

    Raises:
        ValueError: Input list is not one-dimensional.

    Returns:
        np.ndarray: Description of `c`.

    "
""
    return c

让解压这个函数文档字符串的不同部分:

  • [Line 3]: 函数整体效用的总结。
  • [Lines 5-12]: 如何使用功能的例子。
  • [Lines 14-16]: 函数输入参数的描述。
  • [Lines 18-19]:函数中可能引发的任何异常。
  • [Lines 21-22]:函数输出的描述。

将在下面的文档部分呈现这些文档字符串以生成:

文档字符串
文档字符串

花时间用文档字符串更新项目中的所有函数和类,并确保参考存储库作为指南。请注意,您可能必须将某些库显式导入某些脚本,因为type需要它。例如,没有在data.py脚本中明确使用 Pandas 库,但是,确实使用 pandas 数据帧作为输入参数。

# tagifai/data.py
import pandas as pd
from typing import List

def replace_oos_labels(df: pd.DataFrame, labels: List, label_col: str, oos_label: str = "other"):
    ...

理想情况下,会在开发函数和类时将文档字符串添加到它们中,而不是在最后一次完成。

Tip

如果使用Visual Studio Code,请务必使用Python Docstrings Generator扩展,这样您就可以"""在函数下键入,然后点击该Shift键生成模板文档字符串。它将使用输入信息甚至代码中的异常自动填充部分文档字符串!

vscode 文档字符串生成
vscode 文档字符串生成

文档

所以正在经历所有这些努力,将类型和文档字符串包括到函数中,但它们都隐藏在脚本中。如果可以收集所有这些努力并自动将其显示为文档会怎样?好吧,这正是将对以下开源包所做的 → 最终结果在这里。

  1. 安装所需的包:

    pip install mkdocs==1.3.0 mkdocstrings==0.18.1

    不会将这些要求直接添加到requirements.txt文件中,而是将其与所需的核心库隔离开来。想这样做是因为不是每个人都需要创建文档,因为它不是核心机器学习操作(训练、推理等)。将调整setup.py脚本来实现这一点。将在一个docs_packages对象下定义这些包:

    # setup.py
    docs_packages = [
        "mkdocs==1.3.0",
        "mkdocstrings==0.18.1"
    ]

    然后将其添加到setup()脚本中的对象:

# Define our package
setup(
    ...
    install_requires=[required_packages],
    extras_require={
        "dev": docs_packages,
        "docs": docs_packages,
    },
)

现在可以安装这个包:

python3 -m pip install -e ".[docs]"

还定义了一个dev选项,将在课程中更新该选项,以便开发人员可以在一次调用中安装所有必需的和额外的包,而不是一次调用每个额外的必需包。

python3 -m pip install -e ".[dev]"

创建了一个显式doc选项,因为用户只想下载文档包来生成文档(不需要其他包)。当使用CI/CD 工作流通过 GitHub Actions 自动生成文档时,将看到这一点。

  1. 初始化 mkdocs

    python3 -m mkdocs new .

    这将创建以下文件:

    .
    ├─ docs/
    │  └─ index.md
    └─ mkdocs.yml
  2. 将首先用项目的特定信息 覆盖index.md目录中的默认文件:docs

    ## Documentation

    - [Workflows](tagifai/main.md): main workflows.
    - [tagifai](tagifai/data.md): documentation of functionality.

    ## MLOps Lessons

    Learn how to combine machine learning with software engineering to develop, deploy & maintain production ML applications.

    - Lessons: [https://madewithml.com/](https://madewithml.com/#mlops)
    - Code: [GokuMohandas/mlops-course](https://github.com/GokuMohandas/mlops-course)
  3. 接下来将为目录中的每个脚本创建文档文件tagifai

    mkdir docs/tagifai
    cd docs/tagifai
    touch main.md utils.md data.md train.md evaluate.md predict.md
    cd ../../

docs目录结构尽可能模仿项目的结构是有帮助的。随着在以后的课程中记录更多目录,这一点变得更加重要。

  1. 接下来将添加tagifai.<SCRIPT_NAME>docs/tagifaitagifai/<SCRIPT_NAME>.py这将使用有关mkdocstrings插件的函数和类(使用它们的文档字符串)的信息填充文件。

    请务必查看mkdocs 插件的完整列表。

    # docs/tagifai/data.md
    ::: tagifai.data
  2. 最后,将在mkdocs.ymlmkdocs 自动创建的文件中添加一些配置:

    # mkdocs.yml
    site_name: Made With ML
    site_url: https://madewithml.com/
    repo_url: https://github.com/GokuMohandas/mlops-course/
    nav:
      - Home: index.md
      - workflows:
        - main: tagifai/main.md
      - tagifai:
        - data: tagifai/data.md
        - evaluate: tagifai/evaluate.md
        - predict: tagifai/predict.md
        - train: tagifai/train.md
        - utils: tagifai/utils.md
    theme: readthedocs
    plugins:
      - mkdocstrings
    watch:
      - .  # reload docs for any file changes
  3. 在本地提供文档:

    python3 -m mkdocs serve

出版

可以使用公共存储库的GitHub 页面以及私有存储库的私有文档轻松地免费提供文档。甚至可以将其托管在自定义域(例如公司的子域)上。

请务必查看为应用程序自动生成的文档页面。每次对代码库进行更改时,将在CI/CD课程中学习如何自动创建文档并使文档保持最新。

信息架构构建

信息架构的逻辑呈现的 5 个过程

图片
图片

本文主体源自以下链接:

@article{madewithml,
    author       = {Goku Mohandas},
    title        = { Made With ML },
    howpublished = {\url{https://madewithml.com/}},
    year         = {2022}
}

本文由 mdnice 多平台发布

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

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

相关文章

【云享·人物】华为云AI高级专家白小龙:AI如何释放应用生产力,向AI工程化前行?

摘要&#xff1a;AI技术发展&#xff0c;正由应用落地阶段向效率化生产阶段演进&#xff0c;AI工程化能力将会不断深入业务&#xff0c;释放企业生产力。本文分享自华为云社区《【云享人物】华为云AI高级专家白小龙&#xff1a;AI如何释放应用生产力&#xff0c;向AI工程化前行…

通过SCADA实现KPI分析和预测性维护远比想象中简单

一、前言 随着工业发展的不断进步&#xff0c;越来越多的企业开始注重KPI分析和预测性维护。通过数据分析实现智能制造已经成为不可缺少的环节。制定并分析关键绩效指标&#xff08;KPI&#xff09;是实现数据分析战略的重要一步&#xff0c;因为只有跟踪这些关键绩效指标才能…

【自然语言处理(NLP)】基于Bi-DAF的机器阅读理解

【自然语言处理&#xff08;NLP&#xff09;】基于Bi-DAF的机器阅读理解 作者简介&#xff1a;在校大学生一枚&#xff0c;华为云享专家&#xff0c;阿里云专家博主&#xff0c;腾云先锋&#xff08;TDP&#xff09;成员&#xff0c;云曦智划项目总负责人&#xff0c;全国高等学…

Flume环境搭建

1、新建一个专门放文件的目录&#xff1a;mkdir /export/server 2、将Flume的安装包上传到/export/server目录并解压&#xff0c;重命名&#xff1a; tar -zxvf apache-flume-1.8.0-bin.tar.gz -C /export/server mv apache-flume-1.8.0-bin flume 3、修改flume-env.sh文件…

威尔士和英格兰同属英国,但为啥还要在世界杯上进行PK?

聊到威尔士VS英格兰队的比赛&#xff0c;那就不得不普及一个足球常识啊。当我们打开英国的地图&#xff0c;你会发现有四个地区英格兰&#xff0c;苏格兰&#xff0c;威尔士和北爱尔兰都是属于英国的。我们还会常常看到英格兰&#xff0c;苏格兰&#xff0c;威尔士和北爱尔兰四…

FPGA控制W5500完成UDP环回测试

FPGA控制W5500完成UDP环回测试&#xff11; 前言&#xff12; 前期准备&#xff13; &#xff37;5500寄存器描述4 &#xff37;5500 环回测试4.1 W5500初始化4.1.1 通用寄存器初始化4.1.2 socket寄存器初始化4.2 W5500数据接收4.3 W5500数据发送4.4 数据环回5 总结&#x…

Android: SimpleAdapter+GridView 简单图片展示

1&#xff1a;原理解析&#xff1a; 一个xml放总布局&#xff0c;一个xml放适配器要加载的模板&#xff08;我喜欢这样理解&#xff09;&#xff1b; java中写适配事件&#xff1b; 2&#xff1a;目录&#xff1a; 3&#xff1a;主布局&#xff1a;最重要的是要放一个GridView …

ByteX-shrink_r源码解析

背景 为什么要对R文件内联处理&#xff1f; 这里首先说一下Android R文件的产生&#xff0c;对于Android开发者我们都知道&#xff0c;当我们要使用要使用一些布局文件&#xff0c;drawable等其他资源时&#xff0c;可以直接用 R.id. R.drawble.等直接使用&#xff0c;而这个…

易基因科技|单细胞甲基化测序低至2500元/样

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。12月活动来袭&#xff5e; 限时特惠&#xff01;单细胞甲基化测序低至2500元/样&#xff01; 易基因高通量单细胞DNA甲基化测序&#xff1a;单细胞DNA甲基化组学研究很大程度上受制于建库…

定时执行专家 —— 使用网络唤醒功能实现远程开机

目录 ◆ 关于网络唤醒 ◆ 定时执行专家 - 远程开机功能 - 设置方法 ◆ 使用网络唤醒实现远程开机的一些前提条件 ◆ 关于网络唤醒 Wake-on-LAN简称WOL或WoL&#xff0c;中文多译为“网上唤醒”、“远程唤醒”技术。WOL是一种技术&#xff0c;同时也是该技术的规范标准&…

CSS自定义属性与前端页面的主题切换

基于级联变量的CSS自定义属性&#xff0c;已经出来很多年了。 虽然有less、sass等预处理器大行其道&#xff0c;但是自定义属性也有它的特点和用处&#xff0c;诸如在js中读写、作用域设置等等&#xff0c;在处理UI主题切换等功能上也发挥着很大的作用。 自定义属性 CSS自定义…

[附源码]SSM计算机毕业设计学习资源共享与在线学习系统JAVA

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Linux驱动: rtc子系统

1. 前言 限于作者能力水平&#xff0c;本文可能存在的谬误&#xff0c;因此而给读者带来的损失&#xff0c;作者不做任何承诺。 2. 背景 本文分析代码基于Linux 3.10内核&#xff0c;硬件平台为嵌入式ARM32平台. 3. rtc子系统 3.1 相关代码文件列表 drivers/rtc/class.c …

Lactoferrin-PEG-alginate 乳铁蛋白-聚乙二醇-海藻酸钠

产品名称&#xff1a;乳铁蛋白-聚乙二醇-海藻酸钠 英文名称&#xff1a;Lactoferrin-PEG-alginate 纯度&#xff1a;95% 存储条件&#xff1a;-20C&#xff0c;避光&#xff0c;避湿 外观:固体或粘性液体&#xff0c;取决于分子量 PEG分子量可选&#xff1a;350、550、750、1k、…

Redis高级篇——Redis的优化

一、Redis的键值设计 1.1key的结构 Redis的Key在自定义时&#xff0c;最好遵循以下三个规则&#xff1a; 基本格式&#xff1a;[业务名称]&#xff1a;[数据名]&#xff1a;[id]长度不超过44字节不包含特殊字符 如&#xff1a;登录业务&#xff0c;保存用户信息的key 定义为…

python常用代码总结2

1、列表的常规追加元素、追加列表操作 (1)列表追加多个元素&#xff0c;比如追加0-9 ls [] ls.extend(list(range(10)))ls Out[20]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] (2)列表追加多个相同的元素&#xff0c;比如追加10个0 ls1 [] for i in range(10):ls1.append(0)ls1 Ou…

直播邀请函 | 第12届亚洲知识产权营商论坛:共建创新价值 开拓崭新领域

由香港特别行政区政府、香港贸易发展局及香港设计中心共同举办的亚洲知识产权营商论坛&#xff0c;每年为世界各地知识产权业界专家、商界领袖提供一个理想平台&#xff0c;共同探讨亚洲知识产权市场的最新发展&#xff0c;发掘更多商机。 去年&#xff0c;论坛共邀请70余位国…

聚观早报 | 中国茶申遗成功;特斯拉市值蒸发4个推特

今日要闻&#xff1a;中国茶申遗成功&#xff1b;特斯拉市值蒸发4个推特&#xff1b;iPhone14Pro出货量预期下调&#xff1b;FF91距交付仅剩一步之遥&#xff1b;AI绘画一天新增60万用户中国茶申遗成功 11月29日晚&#xff0c;我国申报的“中国传统制茶技艺及其相关习俗”在摩洛…

[附源码]JAVA毕业设计高速公路服务区管理系统(系统+LW)

[附源码]JAVA毕业设计高速公路服务区管理系统&#xff08;系统LW&#xff09; 目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项…

最全面的Spring教程(五)——文件上传与下载

前言 本文为 【SpringMVC教程】文件上传与下载 相关知识&#xff0c;具体将对使用MultipartResolver处理文件上传的步骤&#xff0c;两种文件下载方式&#xff08;直接向response的输出流中写入对应的文件流、使用 ResponseEntity<byte[]>来向前端返回文件&#xff09;等…