cookiecutter-uv 0.0.10版本发布:Python项目模板的重大更新
cookiecutter-uv是一个基于Python的现代化项目模板生成工具,它结合了cookiecutter的灵活性和uv的高效性,为开发者提供了一套标准化的项目结构和最佳实践。该项目模板特别适合需要快速启动Python项目的开发者,内置了诸多现代化工具链的支持。
项目结构布局选项
0.0.10版本引入了对src布局的支持,这是Python项目组织方式的一个重要选择。传统布局直接将模块放在项目根目录下,而src布局则将源代码放在专门的src目录中。这种布局方式有以下优势:
- 避免导入冲突:防止开发时意外导入已安装的包而非本地开发版本
- 更清晰的项目结构:明确区分源代码和项目配置/文档等文件
- 更好的测试隔离:测试代码可以更明确地引用被测试模块
开发者现在可以在创建项目时选择使用传统布局还是src布局,模板会自动配置相应的项目结构和工具链支持。
构建与发布流程优化
本次更新将构建和发布流程迁移到了uv build和uv publish命令,并切换到了hatchling作为构建后端。这些变更带来了以下改进:
- 更快的构建速度:uv工具链相比传统工具(pip、setuptools等)有显著的性能提升
- 更现代的构建系统:hatchling作为PEP 517兼容的构建后端,提供了更灵活的配置方式
- 简化的发布流程:
uv publish命令集成了打包、验证和上传到PyPI的完整流程
开发环境与容器支持
0.0.10版本对开发环境进行了多项改进:
- 开发容器修复:确保在VS Code等支持Dev Containers的IDE中能够正确初始化环境
- Dockerfile优化:将
ADD指令替换为更安全的COPY指令,遵循Docker最佳实践 - 新增Podman支持:为使用Podman替代Docker的用户提供了兼容性支持
这些改进使得无论是本地开发还是基于容器的开发都能获得更好的体验。
工具链更新与精简
本次发布对项目依赖的工具链进行了多项更新和优化:
- 移除Prettier:简化前端工具链,专注于Python生态的工具
- 版本升级:将uv升级到0.6.20,ruff和deptry等工具也更新到最新版本
- 依赖检查修复:确保deptry工具在
src布局下能正确工作
测试与代码覆盖率
新增了对Codecov令牌访问的支持,使得私有仓库或需要认证的项目也能方便地集成代码覆盖率报告。这一改进使得项目的测试基础设施更加完善,有助于维护代码质量。
配置与自动化改进
0.0.10版本对项目配置和自动化流程进行了多项优化:
- JSON文件处理:修复了cookiecutter.json参数顺序问题,并跳过了JSON文件的自动重新排序
- 依赖管理:通过deptry等工具确保项目依赖的准确性和一致性
- 构建系统配置:优化了hatchling后端的配置,确保构建过程更加可靠
总结
cookiecutter-uv 0.0.10版本带来了多项重要改进,从项目结构选择到构建发布流程,再到开发环境支持,都进行了全面优化。这些变更使得基于该模板创建的Python项目能够更好地利用现代Python生态的工具和最佳实践,提高开发效率和项目质量。
对于Python开发者来说,使用这个版本的模板可以快速获得一个配置完善、工具链现代化的项目基础,从而将更多精力集中在业务逻辑开发而非项目配置上。特别是对需要频繁创建新项目的团队或个人开发者,这些改进将显著提升工作效率。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust078- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
Hy3-previewHy3 preview 是由腾讯混元团队研发的2950亿参数混合专家(Mixture-of-Experts, MoE)模型,包含210亿激活参数和38亿MTP层参数。Hy3 preview是在我们重构的基础设施上训练的首款模型,也是目前发布的性能最强的模型。该模型在复杂推理、指令遵循、上下文学习、代码生成及智能体任务等方面均实现了显著提升。Python00