郑文峰的博客 郑文峰的博客
首页
分类
标签
归档
关于
  • 导航 (opens new window)
  • 代码片段 (opens new window)
  • 收藏
  • 友链
  • 外部页面

    • 开往 (opens new window)
GitHub (opens new window)

zhengwenfeng

穷则变,变则通,通则久
首页
分类
标签
归档
关于
  • 导航 (opens new window)
  • 代码片段 (opens new window)
  • 收藏
  • 友链
  • 外部页面

    • 开往 (opens new window)
GitHub (opens new window)
  • 编程
  • python
  • 其他
zhengwenfeng
2025-05-12
目录

基于pre-commit的Python代码规范落地实践

# 简介

pre-commit 是一个开源工具,用于管理和执行 Git 钩子,确保代码库的一致性和质量。通过在提交代码前自动运行代码风格检查(Linting)和格式修正(Formatting),它有助于保持项目代码的统一标准。本文将通过一个 Python 项目的实例,展示如何配置 pre-commit 工作流。

本文旨在介绍使用 pre-commit 对 Python 项目进行代码检查的方法,以提前发现并解决代码中的问题,提高代码的整体质量。文中提及的所有代码示例可以在 pre-commit-demo (opens new window) 找到。

# 使用

  1. 安装

首先,安装 pre-commit:

pip install pre-commit
1

安装成功后,您可以通过以下命令验证安装是否成功:

$ pre-commit --version 
pre-commit 4.2.0
1
2

接下来,设置 Git 钩子脚本:

$ pre-commit install
pre-commit installed at .git/hooks/pre-commit
1
2
  1. 创建配置文件 在项目的根目录下创建 .pre-commit-config.yaml 文件,并推荐使用最新稳定版:
repos:
  - repo: https://github.com/pre-commit/pre-commit-hooks
    rev: v2.3.0
    hooks:
      - id: check-yaml
      - id: check-json
      - id: check-toml
      - id: end-of-file-fixer
      - id: trailing-whitespace
  - repo: https://github.com/psf/black
    rev: 22.10.0
    hooks:
      - id: black
  - repo: https://github.com/PyCQA/isort
    rev: 5.13.2
    hooks:
      - id: isort
  - repo: https://github.com/PyCQA/flake8
    rev: 7.2.0
    hooks:
      - id: flake8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

配置文件说明:

  • repos: 包含要使用的仓库列表。
  • repo: 每个仓库的 URL。
  • rev: 版本号,建议使用最新稳定版。
  • hooks: 需要执行的钩子列表。
  • id: 各个钩子的标识符。

每个钩子 ID 的具体作用可参考相应仓库的官方文档。

  1. 执行与应用

在执行 commit 命令时,会自动调用配置文件中定义的钩子脚本,检查代码是否符合规范。例如:

$ pre-commit_demo % git add *
$ pre-commit_demo % git commit -m "add main.py"
Check Yaml...........................................(no files to check)Skipped
Check JSON...........................................(no files to check)Skipped
Check Toml...........................................(no files to check)Skipped
Fix End of Files.........................................................Passed
Trim Trailing Whitespace.................................................Passed
black....................................................................Passed
isort....................................................................Passed
flake8...................................................................Passed
[main 27890fe] add main.py
 1 file changed, 1 insertion(+)
 create mode 100644 main.py
1
2
3
4
5
6
7
8
9
10
11
12
13

默认情况下,仅检查新添加或修改的文件。若需手动检查所有文件,可以使用如下命令:

$ pre-commit run --all-files
Check Yaml...............................................................Passed
Check JSON...........................................(no files to check)Skipped
Check Toml...............................................................Passed
Fix End of Files.........................................................Passed
Trim Trailing Whitespace.................................................Passed
black....................................................................Passed
isort....................................................................Passed
flake8...................................................................Passed
1
2
3
4
5
6
7
8
9

如需临时跳过校验,可在 commit 命令中加上 --no-verify 参数:

$ git commit -m "add main.py" --no-verify
1

# 最佳实践

  1. 将.pre-commit-config.yaml纳入版本控制,确保团队配置一致
  2. 定期运行pre-commit autoupdate保持工具最新版本
  3. 优先修复而不是--no-verify,让规范成为肌肉记忆.

# 总结

通过本文的实践,我们已经为Python项目搭建了自动化代码质检流水线。pre-commit 就像一位尽职的代码审查员,帮我们做到:

  • 规范守护者:自动执行代码格式化(Black/isort)和静态检查(flake8)
  • 效率加速器:拦截问题在提交前,避免CI/CD环节反复返工
  • 团队协作者:统一项目代码风格,降低多人协作成本
#编码工具
上次更新: 2025/05/13, 09:42:32
最近更新
01
使用etcd分布式锁导致的协程泄露与死锁问题
05-13
02
初识 MCP Server
05-01
03
pulsar阻塞导致logstash无法接入日志
10-30
更多文章>
Theme by Vdoing | Copyright © 2022-2025 zhengwenfeng | MIT License | 赣ICP备2025055428号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式