网站首页 > 技术文章 正文
·

推导式和利用文档字符串
文档字符串是 Python 代码文档的关键组成部分。它们提供了一种简单且标准化的方式来记录模块、函数、类和方法,使开发人员能够了解代码组件的用途和功能。在 Python 中,文档字符串只是用三引号(“”“ 或 ''')括起来的字符串文字,直接放置在它记录的元素下方。Python 的内置 help() 函数和文档生成工具(如 Sphinx)利用文档字符串,使其成为可维护和可访问代码的基础。
语法和约定
文档字符串通常遵循 Python 的 PEP 257 样式指南推荐的特定结构:
def example(param1, param2):
"""
Brief description of what the function does.
More detailed explanation if needed, including any
edge cases or considerations.
Args:
param1 (type): Explanation of param1.
param2 (type): Explanation of param2.
Returns:
type: Explanation of the return value.
Raises:
ExceptionType: Explanation of when the exception is raised.
"""
...
这种结构化方法增强了可读性,并帮助工具提取有用的元数据。值得注意的是,第一行应提供函数用途的简要概述,因为某些工具仅提取此初始行进行摘要。
单行文档字符串非常适合简单的函数或方法,其中一行就足以描述目的。
def add(x, y):
"""Add two numbers and return the result."""
return x + y
可以使用其内置的 help() 函数或 __doc__ 属性来访问文档。
help(add) # or example.__doc__
add.__doc__ # or example.__doc__
通过遵守这些实践,Python 开发人员可以创建文档齐全、可维护的代码,从而简化新贡献者的开发和入门流程。
doctest:在文档中进行测试
Python 中的 doctest 模块允许您将代码作为其文档的一部分进行测试,这使其成为快速验证示例和确保您的文档准确的便捷而强大的工具。通过在文档字符串中嵌入可测试的代码示例, doctest 会运行这些示例以确认它们按描述工作。这有助于防止文档中的代码腐烂,因为示例与实际代码行为不一致。
doctest的工作原理
要使用 doctest,只需在函数、方法或模块文档字符串中以 Python 交互式会话的形式添加示例。每个示例都以 >>>(Python REPL 提示符)开头,预期输出紧随其后。当 doctest 运行时,它会将实际输出与预期输出进行比较,并标记任何不匹配。
def add(a: int, b: int) -> int:
"""
Calculate the sum of two numbers.
Example:
>>> add(2, 3)
5
>>> add(-1, 1)
0
>>> add(4.5, 1.5)
6.0
"""
return a + b
当您运行 doctest 时,它将执行文档字符串中的代码并验证结果是否匹配。您可以从命令行在此脚本上调用 doctest:
python -m doctest <filename>.py
或者,您可以在脚本中添加 doctest.testmod() 以在模块作为脚本执行时自动运行测试:
if __name__ == "__main__":
import doctest
doctest.testmod()
虽然 doctest 很方便,但它并不能完全替代更广泛的测试框架,例如 unittest 或 pytest 。它最适合没有复杂设置、拆解或高级断言的简单情况。它还可能难以处理略有不同的输出(如浮点结果或非确定性输出)。
请参阅 add 函数的综合文档以了解
有关 DocString 中附加的有关其用法的更多信息。
def add(a, b):
"""
Calculate the sum of two numbers.
This function takes two numeric inputs, `a` and `b`, and returns their sum.
It is suitable for integers and floating-point numbers.
Parameters:
a (int or float): The first number to add.
b (int or float): The second number to add.
Returns:
int or float: The sum of `a` and `b`.
Example:
>>> add(2, 3)
5
>>> add(-1, 1)
0
>>> add(4.5, 1.5)
6.0
"""
return a + b
将 doctest 合并到您的工作流程中可以使您的代码更可靠,文档更值得信赖,从而使其他人能够有效地理解和验证代码行为。
推导式
Python 推导式是以简洁、可读的方式创建和操作数据的强大工具。此技术允许您直接从其他序列构建序列(如列表、字典或集),所有这些都在一行代码中完成。与使用 Loop 相比,这可能是一个显著的改进。
列表推导式
列表推导式是最常见的类型,通常用于基于现有列表或范围创建列表。
创建 0 到 9 的方格列表的示例 hwo:
# Syntax: [expression for item in iterable if condition]
squares = [x**2 for x in range(10)]
# Output: [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
上面的推导式从 range(10) 中取出每个数字,将其平方,并将其添加到 squares 列表中。您还可以包含条件语句来筛选元素。
如何添加条件以仅包含偶数个方块的示例:
even_squares = [x**2 for x in range(10) if x % 2 == 0]
# Output: [0, 4, 16, 36, 64]
这允许您以高度可读的方式创建筛选和转换的列表。
词典推导
字典推导式对于从序列动态创建字典非常有用。语法类似于列表推导式,但使用键值结构。
创建 0 到 9 的平方字典的示例 hwo:
# Syntax: {key_expression: value_expression for item in iterable if condition}
squares_dict = {x: x**2 for x in range(10)}
# Output: {0: 0, 1: 1, 2: 4, 3: 9, ..., 9: 81}
您还可以像对待列表推导式一样将条件应用于字典推导式。
集合推导式
集合推导式的工作方式与列表推导式类似,但生成的是集合而不是列表。集是无序的,会自动删除重复值,因此当您需要唯一的结果时,这非常有用。
如何为数字 0 到 9 创建一组正方形的示例:
# Syntax: {expression for item in iterable if condition}
squares_set = {x**2 for x in range(10)}
# Output: {0, 1, 4, 9, 16, 25, 36, 49, 64, 81}
您还可以像对待列表推导式一样将条件应用于字典推导式。
生成器推导式
生成器推导式类似于列表推导式,但创建的是生成器而不是列表。生成器一次生成一个项目,并且仅在需要时生成,从而使它们具有内存效率,尤其是对于大型数据集。如果您只需要迭代一次数据,或者数据集太大而无法一次全部放入内存,这将特别有用。
生成器推导式的语法使用括号 () 而不是方括号 [] 或大括号 {}。
如何为数字 0 到 9 的平方创建生成器的示例:
# Syntax: (expression for item in iterable if condition)
squares_gen = (x**2 for x in range(10))
在此示例中,squares_gen 是一个生成器对象,仅当迭代每个正方形时,它才会生成每个正方形。
for square in squares_gen:
print(square)
# Output: 0, 1, 4, 9, 16, 25, 36, 49, 64, 81
但是,请记住,生成器推导式只能迭代一次。如果需要多次访问元素,则列表推导式可能更合适。
- 上一篇: Python 语言如何和 C/C++ 语言交互使用
- 下一篇: Python解释器和交互模式
猜你喜欢
- 2024-12-23 如何在你的项目中混合 Rust 和 Python
- 2024-12-23 一秒开挂!纯 Python 开发 Web 应用
- 2024-12-23 用 Python 与 Windows 交互 - Pywin32库
- 2024-12-23 交互式环境(Python Shell)编写Python代码
- 2024-12-23 这个用Python编写的大数据测试工具,我给100分
- 2024-12-23 Python与Mysql交互库(持续更新)
- 2024-12-23 Python解释器和交互模式
- 2024-12-23 Python 语言如何和 C/C++ 语言交互使用
- 2024-12-23 简单学Python——做一个可交互的图(结合ipywidgets库)
- 2024-12-23 云计算:Python与AWS S3交互
- 05-25Python 3.14 t-string 要来了,它与 f-string 有何不同?
- 05-25Python基础元素语法总结
- 05-25Python中的变量是什么东西?
- 05-25新手常见的python报错及解决方案
- 05-2511-Python变量
- 05-2510个每个人都是需要知道Python问题
- 05-25Python编程:轻松掌握函数定义、类型及其参数传递方式
- 05-25Python基础语法
- 257℃Python短文,Python中的嵌套条件语句(六)
- 257℃python笔记:for循环嵌套。end=""的作用,图形打印
- 256℃PythonNet:实现Python与.Net代码相互调用!
- 251℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 251℃Python实现字符串小写转大写并写入文件
- 106℃原来2025是完美的平方年,一起探索六种平方的算吧
- 90℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 81℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)