A CLI tool for semantic version management
Project description
bump-version-py
专为 Python 项目设计的智能语义化版本管理命令行工具。
简介
bump-version-py 是一个遵循 PEP 440 规范的 Python 项目版本管理工具。它可以自动更新项目版本号,创建 Git 提交和标签,简化版本发布流程。
主要功能
- ✅ 完全遵循 PEP 440 版本规范
- ✅ 支持 pyproject.toml 和 setup.py
- ✅ 支持预发布版本(alpha、beta、rc、dev、post)
- ✅ 自动 Git 集成(提交、标签、推送)
- ✅ 交互式命令行界面
- ✅ 版本号验证工具
- ✅ 安全检查(分支、工作区状态)
安装
# 使用 uv 全局安装
uv tool install ai-app-base-bump-version
开发安装
# 克隆仓库
git clone https://github.com/ai-app-base/bump-version-py.git
cd bump-version-py
# 安装依赖
uv sync
# 全局安装开发版本(类似 npm link)
uv tool install -e .
使用方法
版本升级
在项目根目录运行:
# 完整命令
bump-version-py
# 简写命令
bvp
工具会自动:
- 检测当前版本
- 提供交互式选项
- 更新配置文件
- 创建 Git 提交和标签
- 推送到远程仓库(可选)
版本验证
验证版本号是否符合 PEP 440 规范:
# 完整命令
validate-version-py 1.0.0
# 简写命令
vvp 1.0.0
# 输出示例
✅ Version 1.0.0 is PEP 440 compliant # 退出码 0
❌ Version 'invalid' is not PEP 440 compliant # 退出码 1
在 CI/CD 中使用:
# 在 shell 脚本中
if validate-version-py "$VERSION"; then
echo "版本号有效"
else
echo "版本号无效"
exit 1
fi
# 或使用 Python 模块
python -m bump_version.validate_version 1.0.0
版本格式
遵循 PEP 440 规范的版本号格式:
1.0.0 # 正式版本
1.0.0a0 # Alpha 版本
1.0.0b0 # Beta 版本
1.0.0rc0 # Release Candidate
1.0.0.dev0 # 开发版本
1.0.0.post0 # 后发布版本
配置文件支持
pyproject.toml(推荐)
[project]
name = "my-package"
version = "1.0.0"
# 或 Poetry 项目
[tool.poetry]
name = "my-package"
version = "1.0.0"
setup.py
setup(
name="my-package",
version="1.0.0",
...
)
工作流程示例
基本发布流程
# 1. 开发完成,准备发布新版本
bvp
# 选择 "正式版本 (Production)"
# 选择 "Patch (修订号)"
# 版本:1.0.0 → 1.0.1
# 2. 自动完成
# - 更新 pyproject.toml
# - git commit -m "chore: release 1.0.1"
# - git tag v1.0.1
# - git push --follow-tags
预发布流程
# 1. 创建 Alpha 版本
bvp
# 选择 "Alpha 版本"
# 选择 "Minor (次版本号)"
# 版本:1.0.0 → 1.1.0a0
# 2. 升级到 Beta
bvp
# 选择 "Beta 版本"
# 版本:1.1.0a0 → 1.1.0b0
# 3. 发布正式版
bvp
# 选择 "正式版本 (Production)"
# 版本:1.1.0b0 → 1.1.0
环境变量
BUMP_VERSION_SKIP_PUSH: 设置为任意值时跳过 git push
API 使用
在代码中使用版本验证功能:
from bump_version.validate_version import validate_version
if validate_version("1.0.0"):
print("版本号有效")
else:
print("版本号无效")
注意事项
-
使用前确保:
- 项目已初始化 Git 仓库
- 工作区干净(无未提交的更改)
- 在主分支(main/master)上操作
-
版本号规范:
- 必须符合 PEP 440 规范
- 不要手动添加 'v' 前缀(工具会自动处理)
-
Git 标签格式:
- 自动添加 'v' 前缀:v1.0.0
许可证
ISC
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ai_app_base_bump_version-0.1.0.tar.gz.
File metadata
- Download URL: ai_app_base_bump_version-0.1.0.tar.gz
- Upload date:
- Size: 9.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bfc650dc4e800693c6a438b570145cc23e0f6a9168f6fd06681054e724bd5a7c
|
|
| MD5 |
98b5e52f4765063c218dcc1e515e1c82
|
|
| BLAKE2b-256 |
b19cc440afa19fb6d425be34e660838de46db9e9b72a765694838ea82247675c
|
File details
Details for the file ai_app_base_bump_version-0.1.0-py3-none-any.whl.
File metadata
- Download URL: ai_app_base_bump_version-0.1.0-py3-none-any.whl
- Upload date:
- Size: 10.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d309341c0722a99629adb8089469351ec88d1cb4d32e80b225cb3a25c7eb79cf
|
|
| MD5 |
d107e4c1c8f40a2b2ce3dc224290c717
|
|
| BLAKE2b-256 |
06a6e50f719b721509cdcc6da8db042126593d925e68b70db11c0f95fb2938fc
|