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

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

相关推荐
white-persist1 天前
MCP协议深度解析:AI时代的通用连接器
网络·人工智能·windows·爬虫·python·自动化
顾林海1 天前
Android编译插桩黑科技:ReDex带你给App"瘦个身,提个速"
android·面试·性能优化
新智元1 天前
谷歌杀入诺奖神殿,两年三冠五得主!世界TOP3重现贝尔实验室神话
人工智能·openai
StarPrayers.1 天前
卷积层(Convolutional Layer)学习笔记
人工智能·笔记·深度学习·学习·机器学习
skywalk81631 天前
AutoCoder Nano 是一款轻量级的编码助手, 利用大型语言模型(LLMs)帮助开发者编写, 理解和修改代码。
人工智能
金井PRATHAMA1 天前
描述逻辑对人工智能自然语言处理中深层语义分析的影响与启示
人工智能·自然语言处理·知识图谱
却道天凉_好个秋1 天前
OpenCV(四):视频采集与保存
人工智能·opencv·音视频
minhuan1 天前
构建AI智能体:五十七、LangGraph + Gradio:构建可视化AI工作流的趣味指南
人工智能·语言模型·workflow·langgraph·自定义工作流
codists1 天前
2025年9月文章一览
python
语落心生1 天前
FastDeploy SD & Flux 扩散模型边缘端轻量化推理部署实现
python