Python_编程中代码注释相关格式 PEP8 — Python 官方代码风格指南

一、代码布局(Code Layout)

1. 缩进

复制代码
使用 4 个空格作为一级缩进。
禁止使用 Tab,也不要混用空格和 Tab。

2. 行长度

复制代码
每行代码 不超过 79 个字符(注释和文档字符串建议不超过 72 字符)。
长表达式换行时,推荐使用括号隐式续行(而非反斜杠 \)。
bash 复制代码
# 推荐:使用括号换行
foo = long_function_name(
    var_one, var_two,
    var_three, var_four
)

3. 空行

复制代码
顶级函数和类之间用 两个空行。
类中的方法之间用 一个空行。
函数内部可用空行分隔逻辑块(谨慎使用)。
bash 复制代码
def func_a():
    pass


def func_b():
    x = 1
    y = 2  # 逻辑分段
    return x + y


class MyClass:
    def method1(self):
        pass

    def method2(self):
        pass

二、注释规范(Comments)

1. 原则

复制代码
注释应解释 "为什么" 而非 "做什么"(代码本身应自解释)。
注释必须 与代码同步更新,过时注释比没有更糟。

2. 文档字符串(Docstring)

复制代码
所有模块、类、函数都应有 docstring。
使用 三重双引号 """,遵循 PEP 257。
描述功能、参数、返回值、异常等。
bash 复制代码
def calculate_tax(income: float) -> float:

    """计算个人所得税
    

    :param income: 税前收入
    :return: 应缴税额
    """
    return income * 0.1

3. 行注释

复制代码
与代码至少留 两个空格,以 # 开头,首字母大写,句尾加句号。
bash 复制代码
x = x + 1  # Increment counter.

三、导入语句(Imports)

1. 导入顺序(分组,每组之间空一行)

复制代码
标准库(如 os, sys)
第三方库(如 requests, numpy)
本地应用/项目模块
bash 复制代码
# 标准库
import os
import sys
from datetime import datetime

# 第三方库
import requests
from flask import Flask

# 本地模块
from . import config
from myapp.utils import helper

2. 其他规则

复制代码
每行只导入一个模块(避免 import os, sys)。
避免通配符导入:from module import * 是禁止的。
优先使用 绝对导入,必要时才用相对导入。

四、其他重要建议

复制代码
命名一致性:
    变量/函数:snake_case
    类名:CamelCase
    常量:UPPER_SNAKE_CASE
空格使用:
    逗号后、二元运算符两侧加空格:a = b + c
    括号内不加空格:func(a, b) 而非 func( a, b )

工具推荐(自动检查/格式化)

复制代码
Black:自动格式化代码(强一致性)
Flake8:检查 PEP 8 违规
pylint / ruff:更全面的静态分析
在 CI 或 pre-commit 中集成这些工具,可强制规范落地。

✅ 总结:

Python 的布局规范核心是 清晰、一致、可读。遵循 PEP 8 不仅提升个人代码质量,更是团队协作的基础。项目如有自定义规范,可在 PEP 8 基础上微调,但需确保 组内统一。

相关推荐
曲幽几秒前
FastAPI入门:从简介到实战,对比Flask帮你选对框架
python·flask·fastapi·web·route·uv·uvicorn·docs
万邦科技Lafite几秒前
淘宝开放API批量上架商品操作指南(2025年最新版)
开发语言·数据库·python·开放api·电商开放平台·淘宝开放平台
Chase_______4 分钟前
【JAVA基础指南(二)】快速掌握流程控制
java·开发语言
Slow菜鸟5 分钟前
Java基础架构设计(四)| 通用响应与异常处理(单体/分布式通用增强方案)
java·开发语言·分布式
wheelmouse77886 分钟前
Java工程师Python实战教程:通过MCP服务器掌握Python核心语法
java·服务器·python
世转神风-9 分钟前
qt-初步编译运行报错-When executing step “Make“-无法启动进程“make“
开发语言·qt
ghgxm5209 分钟前
EXCEL使用VBA代码实现按条件查询数据库--简单实用
开发语言·数据仓库·笔记·excel·数据库开发
..空空的人10 分钟前
C++基于protobuf实现仿RabbitMQ消息队列---服务器模块认识1
服务器·开发语言·c++·分布式·rabbitmq·protobuf
码界奇点11 分钟前
基于Golang的微服务API网关系统设计与实现
开发语言·微服务·golang·毕业设计·yapi·源代码管理
sg_knight11 分钟前
Python 中的常用设计模式工具与库
开发语言·python·设计模式