使用cookiecutter创建python项目

一、关于Python项目结构

Python 项目并没有完全统一的 “固定结构”,但行业内有一些广泛遵循的约定俗成的目录结构(尤其针对可分发的包或大型项目)。同时,确实有工具可以快速生成这些标准化结构,提高开发效率,这在实际开发中非常常见。

对于需要打包、发布或多人协作的项目,典型结构如下:

对于简单脚本或小项目,结构可以简化(例如只有 src/ 目录和几个核心文件)。

二、快速生成项目结构的工具Cookiecutter

今天我们介绍一下最流行的项目模板工具Cookiecutter,支持通过模板快速生成标准化结构,不仅限于 Python。

Cookiecutter 是一个由 Audrey Roy Greenfeld(开源社区活跃开发者)发起并主导开发的开源项目,其核心维护团队包括多位社区贡献者,并非由特定商业公司作为 “发行人” 或 “ publisher ” 进行官方发布。

2.1、安装cookiecutter

如果要安装到虚拟化环境下,在虚拟化终端执行“pip install cookiecutter”命令:

2.2、调用标准模板

运行:cookiecutter https://github.com/audreyr/cookiecutter-pypackage(Python 包标准模板),前提是能访问github。

提示:执行改命令要提前安装了git,在宿主机上安装即可,并将git.exe所在目录添加到了path环境变量中。

如果已经创建过项目的话,cookiecutter会在本地创建缓存模板,这样的话可以直接用本地的,用法有:

cookiecutter C:\Users\yourname\.cookiecutters\cookiecutter-pypackage

或者

cookiecutter cookiecutter-pypackage

系统会自动从默认的缓存路径 ~/.cookiecutters/ 下去寻找名为 cookiecutter-pypackage 的模板。

如果长时间用本地的,模板源有更新了,可以在联网时用下面的命令更新本地模板:

cookiecutter https://github.com/audreyfeldroy/cookiecutter-pypackage.git --overwrite-if-exists

下载的模板文件默认缓存在本地的如下目录下:

2.3、创建项目结构

接下来根据模板要求一次输入下面的full_name,可以是作者名称,团队名称,git上的用户名或者昵称,依次输入下面的名称,:

各字段的含义,我列个表:

提示信息含义示例回答重要性
full_name作者/维护者的全名(会写入版权和作者信息)Haitao Luo⭐⭐⭐⭐⭐
email作者的联系邮箱your.email@example.com⭐⭐⭐⭐⭐
github_username您的 GitHub 用户名your-github-username⭐⭐⭐⭐
project_name项目的正式名称(可以包含空格,给人看的)My Awesome Project⭐⭐⭐⭐⭐
project_slug项目的短标识(用于包名、目录名,电脑看的)my_awesome_project⭐⭐⭐⭐⭐
pypi_username您在 PyPI 上的用户名(如果打算发布)your-pypi-username⭐⭐
project_short_description项目的一句话简短描述A Python package that does awesome things.⭐⭐⭐⭐
version项目的初始版本号0.1.0⭐⭐⭐
use_pytest是否使用 pytest 作为测试框架y (推荐)⭐⭐⭐
use_pypi_deployment_with_travis是否配置 Travis CI 自动发布到 PyPIn (除非您明确需要)
add_pyup_badge是否添加 Pyup 安全更新徽章n (可选)
command_line_interface是否添加命令行接口(CLI)Click (推荐) 或 Argparse 或 No⭐⭐

漏了一个pypi_package_name 就是您的包在“Python应用商店”(PyPI)里的“商品名”,需要独一无二且便于用户查找和安装。

创建结束后可以看到左侧树上有了对应的项目结构,并在windows资源管理器查看:

Cookiecutter创建项目结构说明

1. 核心目录

名称说明
src/源代码根目录。这是现代 Python 打包(PyPA)推荐的结构。您的实际包(package)就在这里的某个文件夹下。这种结构可以避免无意中导入本地其他文件而非已安装的包。
tests/测试代码目录。存放所有单元测试和集成测试文件。通常与 src/ 下的模块结构一一对应(例如 src/mypackage/core.py 的测试文件是 tests/test_core.py)。
docs/项目文档目录。通常使用 Sphinx 或 MkDocs 来构建项目的详细文档。
.github/GitHub 工作流配置。里面通常有 workflows/ 文件夹,存放 GitHub Actions 的 YAML 配置文件,用于实现CI/CD(持续集成/持续部署),如自动运行测试、自动发布等。

2. 配置文件(关键文件)

名称说明
pyproject.toml现代Python项目的核心配置文件。取代了旧的 setup.py。它定义了项目构建依赖(如setuptools)、项目元数据(名称、版本、作者)、以及各种工具(如pytest、black、flake8)的配置。这是最重要的文件之一。
LICENSE开源许可证。规定了他人使用您代码的权利和义务。常见的有MIT、Apache 2.0、GPL等。
README.md项目首页文档。这是项目的门面,通常包含项目介绍、安装方法、快速使用示例、贡献指南等。在GitHub和PyPI上会直接显示。
.gitignoreGit忽略规则。指定哪些文件或目录不应该被纳入版本控制(如虚拟环境 venv/、编译缓存 __pycache__/、IDE配置等)。
MANIFEST.in打包附加文件清单。当构建分发包(sdist)时,pyproject.toml 可能不会自动包含所有非代码文件(如文档、静态资源)。这个文件用来指明需要额外包含哪些文件。
.editorconfig编辑器配置。帮助在不同编辑器和IDE之间保持代码风格(如缩进、字符集)的一致性。

3. 文档与规范文件

名称说明
CODE_OF_CONDUCT.md行为准则。规定了社区交流合作的规范,为所有贡献者创造一个友好的环境。
CONTRIBUTING.md贡献指南。详细说明如何为项目做贡献,如如何提交Issue、如何拉取请求(Pull Request)、代码风格要求等。
HISTORY.md更新日志。记录每个版本的重大变更、新增功能和修复的Bug。
justfileJust命令运行器配置just 是一个类似 make 的命令运行工具,用于定义和管理项目常用的命令(如运行测试、构建文档、格式化代码等)。这是一个可选但很方便的工具。

需要注意的是,此时的venv虚拟化环境和通过cookiecutter创建的项目是同一目录级别,这种情况下是一个虚拟化环境适配多个project,如果想做个项目隔离,那么venv虚拟化目录在你创建的project里面,这个换一篇再介绍。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/922452.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/922452.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

台积电生态工程深度解析:从晶圆厂到蜂巢的系统架构迁移

当半导体巨头将工厂视为生态系统,用工程思维解决环境问题概述:生态系统的工程化再造台积电近日开展的"积蜜"项目绝非简单的企业CSR行为,而是一场将生态系统视为复杂系统进行工程化改造的技术实践。本文将从系统架构、数据监控、循环…

从零实现一个简易计算器

最近在刷算法题时,遇到了实现计算器的问题。一开始觉得很简单,但真正动手实现时才发现其中有很多细节需要考虑。今天就来分享一下我的实现思路和学到的经验。问题分析我们需要实现一个能够处理加减乘除四则运算的计算器,要正确处理运算符的优…

Actix-webRust Web框架入门教程

文章目录引言Actix-web是什么?准备工作你的第一个Actix-web应用理解代码结构处理请求和响应接收请求数据返回响应中间件 - 增强你的应用状态管理和依赖注入实用示例:构建RESTful API测试你的Actix-web应用部署Actix-web应用结语额外资源引言 嘿&#xf…

若依框架前端通过 nginx docker 镜像本地运行

1. 前言 项目运行过程图:对于前端项目通过命令 npm run build 打包后,无法直接运行。存在如下错误:可以通过配置 nginx 服务器运行前端项目解决如上问题。 2. Nginx 运行 采用 docker 镜像的方式运行,docker-compose.yml 文件内容…

浅聊一下HTTP协议

在日常上网浏览网页、刷视频时,背后都离不开 HTTP 协议的支持。作为 Web 世界的 “交通规则”,它负责服务器和客户端浏览器之间的数据传输。这篇文章就带大家全面了解 HTTP 协议,从基本概念到通信细节,再到安全相关的 HTTPS&#…

机器人控制器开发(定位——cartographer ros2 使用2)

文章总览 1 纯定位模式 当完成建图后,会生成pbstream格式的地图文件 配置纯定位模式的lua脚本 backpack_2d_localization.lua include "backpack_2d.lua"TRAJECTORY_BUILDER.pure_localization_trimmer {max_submaps_to_keep 3, } POSE_GRAPH.optimi…

《大数据之路1》笔记3:数据管理

一 元数据 1.1 元数据概述 定义: 元数据是关于数据的数据,元数据打通了源数据、数据仓库、数据应用,记录了数据从生产到消费的全部过程。元数据主要记录数据仓库中模型的定义、各层级间的映射关系、监控数据仓库的数据状态和ETL的任务运行状态…

排序实现java

排序算法概述Java中实现排序可以通过多种方式,包括内置方法、自定义算法或使用第三方库。常见的排序算法有冒泡排序、选择排序、插入排序、快速排序、归并排序等。使用Arrays.sort()方法对于数组排序,Java提供了Arrays.sort()方法,支持对基本…

51c大模型~合集182

我自己的原文哦~ https://blog.51cto.com/whaosoft/14174587 #LaV-CoT 超越GPT-4o,蚂蚁集团与南洋理工大学提出:首个语言感知的视觉思维链 随着大型视觉语言模型(VLM)的飞速发展,它们在处理复杂的视…

C++ STL之deque的使用和模拟实现

目录 deque 核心本质与定位 与stack和queue的关系: deque的使用 deque的底层实现 deque的原理介绍 deque的缺陷 总结: deque deque文档 : deque 翻译: 双端队列 deque(通常发音类似“deck”)是“double-ended queue”(双端队列&…

布草洗涤厂设备租赁押金原路退回系统—东方仙盟

设备租赁状态设备管理添加设备设备收押金设备退押金在布草洗涤行业的运营版图中,设备租赁是连接厂商与客户的重要纽带,而押金的收取与退还则是这一环节中关乎信任与效率的关键节点。未来之窗布草洗涤厂深谙此道,专为设备租赁业务打造的 “押金…

换源rocklinux和centos

一、Rockylinux换源,国外的源换成国内的源#nmcli connection modify ens33 ipv4.addresses 192.168.121.11 ipv4.gateway 192.168.121.2 ipv4.method manual ipv4.dns 114.114.114.114 connection.autoconnect yes修改地址#systemctl stop firewalld#systemctl diab…

第一部分:服务器硬件配置

目录1.1 服务器上架与连线1.2 启用CPU虚拟化功能(BIOS设置)1.3 配置RAID存储步骤1:进入RAID配置界面步骤2:确认RAID控制器信息步骤3:创建系统RAID(用于安装ESXi)步骤4:创建数据RAID&…

手搓一个 DELL EMC Unity存储系统健康检查清单

写在前面对于DELL EMC存储系统Unity的一些深度的健康检查通过Web的Unisphere图形化界面是做不到的,图形化界面只能看到是否有告警,物理的东西是否有问题的,逻辑的Pool和LUN等是否ready,再深入的潜在的问题是查不到的。另外&#x…

【数据结构】二叉树的概念

01 概念定义:二叉树既然叫二叉树,顾名思义即度最大为2的树称为二叉树。 它的度可以为 1 也可以为 0,但是度最大为 2 。 一颗二叉树是节点的一个有限集合,该集合:① 由一个根节点加上两棵被称为左子树和右子树的二叉树组…

【RK3576】【Android14】如何在Android14下单独编译kernel-6.1?

单独编译kernel依赖如下几个源码:【交叉编译工具链】prebuilts/clang/host/linux-x86/clang-r487747c【内核源码】kernel-6.1为什么Android下编译内核使用clang作为交叉编译工具链而不是GCC?Android 14 选择使用预置的 Clang 工具链(如 clang…

什么是Redis的Pipeline

介绍Redis的Pipeline是一种网络优化技术,在没有Pipeline的时候,客户端往redis发送请求,客户端需要等到redis响应之后才能发送下一个请求。而Pipeline,使redis可以一次性接收多个请求。减少了通信次数,显著的提高了性能…

【ElementUI el-table跨页勾选】

一、el-table需加上refs和 row-key属性 二、type"selection"勾选框 需加上 reserve-selection储备选择属性 三、在分页请求数据时&#xff0c;触发 setSelected()方法 四、在 selection-change变化时保存 selectedRows <el-table ref"tables" :data&quo…

论文阅读/博弈论/拍卖:《Truthful Auction for Cooperative Communications》

摘要&#xff1a;一方面&#xff0c;协作通信由于其在提升无线网络容量方面的巨大潜力而日益受到关注。另一方面&#xff0c;协作通信技术的实际应用却很少见&#xff0c;即使在一些对带宽需求极高的应用场景中&#xff0c;系统设计者也并未采用协作通信技术来开发创新的网络解…

系统软中间件:连接软件与硬件的桥梁

理解“系统软中间件”这个术语很重要&#xff0c;它实际上是两个紧密相关但又不同的概念的组合&#xff1a; 系统软件中间件 严格来说&#xff0c;“系统软中间件”不是一个标准的独立术语。它通常指的是属于系统软件范畴的中间件&#xff0c;或者理解为作为系统软件重要组成部…