Copier 使用教程
1. 项目目录结构及介绍
Copier 是一个用于渲染项目模板的Python库和命令行工具。其核心概念包括模板、问卷和项目。下面是典型的Copier项目结构:
📁 my_copier_template # 模板项目
│
├── 📄 copier.yml # 模板配置
│
├── 📁 git/ # 模板是一个Git仓库
│
└── 📁 [[project_name]] # 使用模板生成的实际项目名字
└── 📄 [[module_name]].py.jinja # 使用Jinja2模板引擎的文件
my_copier_template
: 存放模板的根目录。copier.yml
: 定义模板配置,包含如何生成项目的信息。git/
: 示例中的文件夹表明模板可能是一个Git仓库。[[project_name]]
和[[module_name].py.jinja]
: 这些是占位符,将根据用户输入自动生成实际的项目名称和模块文件。
2. 项目的启动文件介绍
在Copier项目中,启动文件通常不单独存在,因为它是通过执行copier copy
命令从模板生成的。copier.yml
配置文件定义了模板变量和生成过程。例如,运行以下命令可从模板创建新项目:
copier copy path/to/template path/to/destination
这里的path/to/template
是你存储模板的路径,path/to/destination
则是你想生成新项目的路径。
3. 项目的配置文件介绍
配置文件copier.yml
是Copier的核心部分,它定义了模板的元数据、变量和默认值。下面是一个简单的配置文件示例:
from:
version: "1.0"
questions:
author_name:
default: "Your Name"
prompt: "Enter your full name."
project_license:
default: "MIT"
choices: ["MIT", "Apache-2.0", "GPLv3"]
variables:
year: "{{ now().year }}"
hooks:
pre_copy:
- echo "Running pre-copy hook..."
post_copy:
- echo "Project generated successfully!"
from
: 指定模板的来源,如版本号或其他标识。questions
: 提供用户输入的字段,可以有默认值和提示信息。variables
: 定义可以在模板中使用的变量,可以是动态计算的,如上述示例中的当前年份。hooks
: 提供预复制(pre_copy
)和后复制(post_copy
)的脚本,可以是shell命令或其他动作,在拷贝过程中执行。
以上是Copier的基本使用教程,如果你想要了解更多细节,建议查阅项目的官方文档:https://copier.readthedocs.io/en/stable/。