苦练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 一键开挂
  • 立即格式化,写真正的专业代码

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

相关推荐
不开大的凯20776 分钟前
麦当秀AiPPT战略转向:从SaaS订阅迈向Token经济,AI办公定价模式迎来新探索
大数据·人工智能
Mr数据杨7 分钟前
【CanMV K210】显示交互 LCD1602 I2C 通信与滚动文本显示
人工智能·交互·硬件开发·canmv k210
IT_陈寒9 分钟前
SpringBoot那个自动配置的坑,害我排查到凌晨三点
前端·人工智能·后端
常威正在打来福11 分钟前
不想让你的网页长得像「AI 做的」?试试这个
人工智能·aigc·ai编程
大模型推理12 分钟前
《从 0 实现 SGLang》第 1 篇 · LLM 推理引擎到底在做什么
人工智能
PILIPALAPENG17 分钟前
Python 语法速成指南:前端开发者视角(JS 类比版)
前端·人工智能·python
Binary_Soul23 分钟前
一文读懂:如何让 Claude Code 拥有"过目不忘"的记忆力
人工智能
黎阳之光24 分钟前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
东风破_26 分钟前
Claude Code 实战指南:像带实习生一样让 AI 帮你维护项目
人工智能
常威正在打来福27 分钟前
frontend-design入门指南:OpenClaw/Claude Code/Codex 三平台安装教程
人工智能·aigc·ai编程