苦练Python第20天:Python官方钦定的代码风格指南

苦练Python第20天:Python官方钦定的代码风格指南

原文链接:dev.to/therahul_gu...

作者:Rahul Gupta

译者:倔强青铜三

前言

大家好,我是倔强青铜三 。是一名热情的软件工程师,我热衷于分享和传播IT技术,致力于通过我的知识和技能推动技术交流与创新,欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!

100 天 Python 挑战来到 第 20 天 !今天带你一口气吃透官方代码风格指南 PEP 8,让你的代码瞬间专业、可读、优雅。


📦 今日要点

  • 什么是 Pythonic 代码
  • PEP 8 速览:命名、缩进、行宽、空格、导入、文档
  • 一键格式化神器:Black、flake8、isort
  • 实战 Before vs After 对比

🧠 Pythonic 代码是什么?

  • 易读
  • 简洁却清晰
  • 风格一致
  • 优雅自然

📜 PEP 8 速查表

PEP 8 就是 Python 代码的"语法说明书"。

1️⃣ 4 个空格缩进

python 复制代码
# ✅ 推荐
def greet():
    print("Hello")

# ❌ 不推荐 (Tab键缩进 or 2个空格缩进)

2️⃣ 行宽 ≤ 79

python 复制代码
print("Long strings can be broken with"
      " implicit line continuation.")

3️⃣ 函数间留 2 空行

python 复制代码
def foo():
    pass


def bar():
    pass

4️⃣ 运算符空格

python 复制代码
x = 5 + 2    # ✅
x=5+2        # ❌

5️⃣ 命名规范

类型 风格 示例
变量 snake_case user_name
函数 snake_case get_data()
PascalCase UserProfile
常量 ALL_CAPS MAX_RETRY = 3

6️⃣ 一行只导入一个模块

python 复制代码
import os
import sys          # ✅
# import os, sys   # ❌

导入顺序:

  1. 标准库
  2. 第三方库
  3. 本地模块

7️⃣ 为函数写 docstring

python 复制代码
def add(a, b):
    """Return the sum of a and b."""
    return a + b

8️⃣ 未使用变量用 _

python 复制代码
for _ in range(5):
    print("Hi")

9️⃣ Noneis 判断

python 复制代码
if user is None:   # ✅
    ...

🧰 一键格式化神器

bash 复制代码
pip install black flake8 isort
  • Black:自动格式化
  • flake8:代码检查
  • isort:导入排序

格式化文件:

bash 复制代码
black your_script.py

✨ Before vs After

❌ 不 Pythonic

python 复制代码
def myfunc(x):print(x+  5)

✅ Pythonic

python 复制代码
def my_func(x):
    print(x + 5)

🧼 为什么重要

  • 可读性 ↑
  • 协作效率 ↑
  • Bug 早发现
  • 专业形象 ↑
  • 开源/团队必会

🧠 一日精华

  • Pythonic = 优雅 + 规范
  • PEP 8 十条军规速背
  • Black + flake8 一键开挂
  • 立即格式化,写真正的专业代码

最后感谢阅读!欢迎关注我,微信公众号倔强青铜三。欢迎点赞收藏关注,一键三连!!!

相关推荐
数字化脑洞实验室1 小时前
如何理解不同行业AI决策系统的功能差异?
大数据·人工智能·算法
视觉语言导航1 小时前
RAPID:基于逆强化学习的无人机视觉导航鲁棒且敏捷规划器
人工智能·无人机·具身智能
阿郎_20111 小时前
python自动化脚本-简化留言
python·自动化
TextIn智能文档云平台1 小时前
大模型文档解析技术有哪些?
人工智能
大明者省1 小时前
案例分析交叉熵和交叉验证区别和联系
人工智能·深度学习·神经网络·计算机视觉·cnn
人邮异步社区1 小时前
推荐几本学习计算机语言的书
java·c语言·c++·python·学习·golang
FL16238631293 小时前
古籍影文公开古籍OCR检测数据集VOC格式共计8个文件
人工智能·ocr
gfdgd xi5 小时前
GXDE 内核管理器 1.0.1——修复bug、支持loong64
android·linux·运维·python·ubuntu·bug
递归不收敛6 小时前
专属虚拟环境:Hugging Face数据集批量下载(无登录+国内加速)完整指南
人工智能·笔记·git·python·学习·pycharm
我是小邵6 小时前
主流数据分析工具全景对比:Excel / Python / R / Power BI / Tableau / Qlik / Snowflake
python·数据分析·excel