python注释规范

Python 中的函数注释通常使用文档字符串(docstring)来提供对函数的说明。文档字符串是放置在函数、模块或类的顶部的字符串,用于描述其功能、输入参数、返回值以及其他相关信息。以下是一些建议的 Python 函数注释规范:

使用三重引号: 文档字符串通常由三重引号(单引号或双引号)括起来,以允许跨多行。

def example_function(arg1, arg2):"""This is a docstring that provides a brief description of the function.Args:arg1 (int): Description of arg1.arg2 (str): Description of arg2.Returns:bool: Description of the return value.
"""

描述函数的作用:

在文档字符串的第一行,提供一个简洁而清晰的概述函数的作用。

说明输入参数

在文档字符串中,使用"Args:"部分详细描述每个参数,包括参数的类型和描述。

说明返回值

在文档字符串中,使用"Returns:"部分描述函数的返回值,包括返回值的类型和描述。

提供示例

如果可能的话,为函数提供使用示例,以便用户更容易理解函数的使用方式。

def example_function(arg1, arg2):"""This is a docstring that provides a brief description of the function.Args:arg1 (int): Description of arg1.arg2 (str): Description of arg2.Returns:bool: Description of the return value.Example:>>> example_function(5, 'hello')True
"""

使用类型提示

尽可能使用函数参数和返回值的类型提示。这有助于提高代码的可读性和 IDE 的代码补全功能。

def example_function(arg1: int, arg2: str) ->; bool:"""This is a docstring that provides a brief description of the function.Args:arg1 (int): Description of arg1.arg2 (str): Description of arg2.Returns:bool: Description of the return value.
"""

良好的函数注释有助于其他人理解和使用你的代码,同时也为自动生成文档提供了便利。

补充:函数类型提示细节

注释参数: :参数类型
注释返回值 -> 参数类型
本质:函数对象有一个__annotations__的属性,所有对函数的注释都以键值对的形式存储在这个属性里面

当对一个参数有多个注释的时候可以使用字典的形式添加注释

注意,注释位于默认值之前,例如:
def sum(a : int = 10,b):

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

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

相关文章

本地搭建Linux DataEase数据可视化分析工具并实现公网访问

文章目录 前言1. 安装DataEase2. 本地访问测试3. 安装 cpolar内网穿透软件4. 配置DataEase公网访问地址5. 公网远程访问Data Ease6. 固定Data Ease公网地址 前言 DataEase 是开源的数据可视化分析工具,帮助用户快速分析数据并洞察业务趋势,从而实现业务…

软件测试面试中基础与功能的问题

一、 你们的测试流程是怎么样的? 答:1.项目开始阶段, BA (需求分析师) 从用户方收集需求并将需求转化为规格说明书,接 下来在 项目组领导 会组织需求评审。 2.需求评审通过后,BA 会组织 项目…

React中类组件和函数组件的区别?

面试官:说说对React中类组件和函数组件的理解?有什么区别? 一、类组件 类组件,顾名思义,也就是通过使用ES6类的编写形式去编写组件,该类必须继承React.Component 如果想要访问父组件传递过来的参数&#…

剑指 Offer(第2版)面试题 28:对称的二叉树

剑指 Offer(第2版)面试题 28:对称的二叉树 剑指 Offer(第2版)面试题 28:对称的二叉树解法1:递归解法2:镜像二叉树 前序遍历 剑指 Offer(第2版)面试题 28&…

kernel(三):kernel移植

本文主要探讨210官方kernel移植。 配置文件选择 选择配置文件smdkv210_android_defconfig(arch/arm/configs) 修改主Makefile 配置cpu架构和交叉编译工具链 vim MakefileARCH ? armCROSS_COMPILE ? /root/arm-2009q3/bin/arm-none-linux-gnueabi- 初步编译烧…

使用对象处理流ObjectOutputStream读写文件

注意事项: 1.创建的对象必须实现序列化接口,如果属性也是类,那么对应的类也要序列化 2.读写文件路径问题 3.演示一个例子 (1)操作的实体类FileModel,实体类中有Map,HashMap这些自带的本身就实现了序列化。 public class File…

Gradio: 实时性能反馈的机器学习演示工具 | 开源日报 No.107

comfyanonymous/ComfyUI Stars: 17.5k License: GPL-3.0 这个项目是 ComfyUI,它提供了一个图形化界面和后端来设计和执行复杂的稳定扩散工作流程。 节点/图表/流程图接口用于实验并创建复杂的稳定扩散工作全面支持不同版本的 Stable Diffusion异步队列系统部分更新…

薅github的羊毛-用pages建自己的博客或资源站 - 博客工具 - 2/2

笔者调研了好多个静态博客工具,最后锁定Hexo了,但不等于其他博客不行。我只吐槽两个 Hugo - 难用Gridea - 简直就是骗钱的,我交钱用不了 theme没有链接,同步也同步不了,估计以前是可以,现在经营不下去&…

十大经典排序算法知识体系终结篇

目录 一. 前言 二. 冒泡排序(Bubble Sort) 2.1. 概念 2.2. 算法步骤 2.3. 代码实现 三. 选择排序(Selection Sort) 3.1. 概念 3.2. 算法步骤 3.3. 代码实现 四. 插入排序(Insertion Sort) 4.1. …

wireshark使用

1、抓包界面介绍 2、过滤 (1) ip过滤 or 端口过滤 ip.src 192.168.1.104 显示源地址为192.168.1.104的数据包列表 ip.dst192.168.1.104, 显示目标地址为192.168.1.104的数据包列表 ip.addr 192.168.1.104 显示源IP地址或目标IP地址为192.168.1.104的数据包列表 port 80 …

C++进阶篇9---类型转换

C语言中的类型转换 在C语言中,如果赋值运算符左右两侧类型不同,或者形参与实参类型不匹配,或者返回值类型与 接收返回值类型不一致时,就需要发生类型转化,C语言中总共有两种形式的类型转换:隐式类型 转换和…

RRC下的NAS层

无线资源控制(Radio Resource Control,RRC),又称为无线资源管理(RRM)或者无线资源分配(RRA),是指通过一定的策略和手段进行无线资源管理、控制和调度,在满足服…

2.操作符详解

1.10进制转二进制方法 所以125的二进制就是1111101 2.2进制转8进制: 从2进制序列中右边最低位开始向左每3个2进制位换算为一个8进制位,剩余不够3个2进制位的直接换算 例:01101011转为01 101 011 即1 5 3 即8进制的153 还原回去的话: 将3化为011放最右边,5化…

使用PM2,在生产环境稳定运行你的node项目

PM2 一个 node&#xff0c;本身就用几行代码&#xff0c;就可以启动个 server 进程&#xff0c;监听个端口&#xff0c;为大家提供 Web 服务 一、依赖安装 npm install pm2 -g 二、命令行启动 普通执行启动 pm2 start <js 文件路径 >.js 携带参数启动 pm2 start < 某种…

【数学】整除与同余

基本概念 在数论中&#xff0c;整除不得不说是一种最为基础的知识了。 a a a 整除 b b b&#xff0c;记作 a ∣ b a|b a∣b 设 a , b ∈ Z a,b\in\Z a,b∈Z 且 b ≠ 0 b\ne 0 b0&#xff0c;则 b ∣ a b|a b∣a 当且仅当 ∃ q ∈ Z \exist q\in\Z ∃q∈Z 满足 q b …

re:Invent 云端历程:Swami Sivasubramanian 博士主题演讲-数据共生与开放

re:Invent 云端历程&#xff1a;Swami Sivasubramanian 博士主题演讲-数据共生与开放 亚马逊云科技 re:Invent 大会简介 亚马逊云科技 re:Invent 是亚马逊云科技为全球云计算社区举办的学习大会。是云计算领域的行业风向标&#xff0c;科技界的全球年度重磅盛会。 亚马逊云科…

Golang 领域驱动设计(DDD)最佳实践

Golang 领域驱动设计(DDD)最佳实践 Golang 领域驱动设计(DDD)最佳实践背景整体设计合理的创建标题,有助于目录的生成代码实现领域层什么是实体(Entity)?基础设施层数据对象表现层一些技巧检查结构体是否实现了某接口的防御代码适应于 Go Web 应用的错误处理对象拷贝Gol…

Docker笔记:简单部署 nodejs 项目和 golang 项目

docker 简单的维护 nodejs 项目容器 1 &#xff09;Nodejs 程序 const express require(express) const app express()app.get(/, (req, res) > {res.send(首页) })app.get(/news, (req, res) > {res.send(news) })// dokcer 做端口映射不要指定ip app.listen(3000)2…

爬虫学习日记第九篇(爬取seebug)

目标&#xff1a;https://www.seebug.org/vuldb/vulnerabilities 需求&#xff1a;爬取cve_id及影响组件 单线程 cookie是有时效的(过一段时间就不行了&#xff0c;大概半小时左右)&#xff0c;但是并不需要登录(直接抓包拿到的请求头) import base64 import json import ur…

vue 封装对象深拷贝方法

vue 封装对象深拷贝方法 在 src/ utils文件夹下面新建index.js // index.js// 深拷贝对象 export function deepClone(obj) {const _toString Object.prototype.toString// null, undefined, non-object, functionif (!obj || typeof obj ! object) {return obj}// DOM Nodei…