0

0

Poetry项目:创建可执行的命令行工具

花韻仙語

花韻仙語

发布时间:2025-11-30 12:35:25

|

336人浏览过

|

来源于php中文网

原创

Poetry项目:创建可执行的命令行工具

本文介绍如何使用poetry将python项目配置为可直接从命令行运行的工具。通过在`pyproject.toml`文件中配置`[tool.poetry.scripts]`部分,开发者可以定义一个入口点,使项目模块在安装后能够像原生命令一样被调用,无需`python -m`。这种方法简化了命令行工具的部署和使用,提升了用户体验。

在Python项目开发中,尤其当项目旨在提供命令行实用工具时,我们通常希望用户能够像使用系统原生命令一样直接调用它,而不是每次都通过python -m your_module的方式。Poetry作为一款强大的Python依赖管理和打包工具,提供了简洁高效的方式来实现这一目标,即通过在pyproject.toml文件中定义可执行脚本。

配置可执行脚本

Poetry通过pyproject.toml文件中的[tool.poetry.scripts]部分来定义可执行的命令行工具。这个配置项允许你指定一个脚本名称(即用户在命令行中键入的命令)以及它对应的Python入口点。

基本语法:

[tool.poetry.scripts]
<command_name> = '<module_path>:<function_name>'
  • :这是用户在终端中将要执行的命令名称。例如,如果你希望用户键入mycli来运行你的工具,那么这里就写mycli。
  • :这是包含入口函数的Python模块的路径。例如,如果你的入口函数在my_package/console.py中,那么模块路径就是my_package.console。
  • :这是在指定模块中被调用的函数名称。当用户执行时,Poetry会确保调用这个函数。

示例:

假设你有一个名为my_package的Poetry项目,并且希望创建一个名为my_package_cli的命令行工具。这个工具的入口函数位于my_package/console.py文件中的run函数。

MediPro商贸信息网站系统
MediPro商贸信息网站系统

基于PHP+MYSQL开发,具有完善的企业、信息、产品、文章发布和管理功能,灵活的会员权限控制和会员管理系统,灵活的可视化模版引擎,HTML静态页面生成和多语言支持,丰富的网站辅助工具,用于创建行业商贸信息网站、地方商贸信息门户网站。v5.1版本增加了多项功能,支持了PHP5+MYSQL5环境,前台网站插件开放源码,更利于个性化的商贸网站开发。主要功能模块:企业名录系统 - 企业介绍发布和企业名录

下载
  1. 创建或修改 pyproject.toml 文件: 在你的项目根目录下的pyproject.toml文件中,添加或修改[tool.poetry.scripts]部分,如下所示:

    # pyproject.toml
    [tool.poetry]
    name = "my_package"
    version = "0.1.0"
    description = "A sample Poetry project with a CLI"
    authors = ["Your Name <your.email@example.com>"]
    
    [tool.poetry.dependencies]
    python = "^3.8"
    
    [tool.poetry.dev-dependencies]
    pytest = "^5.2"
    
    [tool.poetry.scripts]
    my_package_cli = 'my_package.console:run' # 定义命令行工具
  2. 创建入口模块和函数: 在你的my_package目录(即与pyproject.toml中name字段对应的包名)下,创建console.py文件,并定义run函数:

    # my_package/console.py
    
    def run():
        """
        This function will be executed when 'my_package_cli' is called.
        """
        print("Hello from my_package_cli!")
        print("This is a command-line utility powered by Poetry.")
    
    if __name__ == '__main__':
        run()

安装与使用

完成上述配置和代码编写后,你需要执行以下步骤来安装并使用你的命令行工具:

  1. 安装项目依赖: 在项目根目录下,运行Poetry的安装命令。这将安装项目的所有依赖,并根据[tool.poetry.scripts]配置创建可执行脚本。

    poetry install

    如果你的项目已经安装过,并且你只是添加了[tool.poetry.scripts]配置,你可能需要再次运行poetry install来更新环境。

  2. 执行命令行工具: 安装完成后,你就可以在Poetry项目的虚拟环境中直接调用你定义的命令了:

    my_package_cli

    你将看到my_package/console.py中run函数定义的输出:

    Hello from my_package_cli!
    This is a command-line utility powered by Poetry.

注意事项与总结

  • 虚拟环境激活: poetry install会在当前Poetry项目对应的虚拟环境中创建可执行脚本。因此,你需要确保在执行my_package_cli命令时,该虚拟环境是激活的(例如,通过poetry shell进入)。
  • 全局安装: 如果你将此Poetry项目打包并通过pip install安装到其他环境中(例如,作为PyPI包发布),那么这个命令行工具也会在目标环境中可用,无需手动激活Poetry虚拟环境。Poetry和pip都会负责将脚本添加到系统PATH中(或其等效位置)。
  • 入口点清晰: 确保你的入口函数(如示例中的run)不接受任何参数,或者能够优雅地处理无参数调用,因为命令行工具通常会在不带参数的情况下被调用。如果需要处理命令行参数,你可以在run函数内部使用argparse等库来解析sys.argv。
  • 错误处理: 在实际的命令行工具中,应包含适当的错误处理和用户友好的输出信息。

通过[tool.poetry.scripts],Poetry极大地简化了Python项目向可执行命令行工具的转换过程,使其与传统的setup.py或手动脚本创建相比,更加现代化和便捷。这种方法不仅提升了开发效率,也为最终用户提供了更直观、更专业的工具使用体验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

434

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

801

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

370

2025.07.23

console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

420

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

541

2024.05.29

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号