Poetry:给你一个优雅的Python项目管理方式
off999 2024-11-05 10:57 36 浏览 0 评论
简单来讲,通过使用Poetry ,让Python终于有了一种管理开发项目的虚拟环境和依赖关系的优雅方式。
0.导引
“There should be one — and preferably only one — obvious way to do it.”(应该有一种——最好只有一种——显而易见的方法来做到这一点。)
虽然这句话出自蒂姆.彼得斯的《Python之禅》,但Python并不总是遵循这一原则。Python没有达到理想的一个领域是项目管理。很长一段时间以来,管理Python项目涉及到工具和方法的大杂烩。然而,事实上的标准可能是新兴的Poetry。
Poetry(https://python-poetry.org/)给Python带来了Go和Rust长期以来所喜爱的那种一体化项目管理工具。Poetry允许项目对特定的包版本有确定性的依赖关系,因此它们在不同的地方一致地构建。Poetry还使构建、打包和向PyPI发布项目和库变得更加容易,这样一来,其他人就可以分享您的Python工作成果。
在本文中,我们将介绍在Python开发项目中Poetry的使用——如何设置Poetry,如何用Poetry配置项目的依赖关系和虚拟环境,以及如何避免Poetry独特的工作方式带来的一些陷阱。
1.Python中配置Poetry
Poetry(https://python-poetry.org/)与其他Python依赖项和项目管理工具有所不同,从配置开始。与使用pip不同,Poetry使用自定义安装程序(https://python-poetry.org/docs/#installation)。安装程序将Poetry应用程序添加到用户的配置文件目录中,因此它可应用于系统中当前或将来的任何Python安装。
尽管您可以使用pip install poetry在特定的Python安装中安装Poetry,但不建议这样做,因为:a)它可能会与其他系统文件冲突;b)它会使在不同的Python版本和不同的虚拟环境中一致使用Poetry变得困难。
2.创建Poetry托管的Python项目
安装了Poetry之后,只需输入poetry new <project_name>,就可以创建一个新的Poetry托管/管理项目目录。这个命令创建了一个名为<project_name>的子目录,并使用一个项目脚手架填充该目录。
Poetry项目“脚手架”包括以下内容:
- pyproject.toml——项目定义文件。Poetry为你管理这个定义。如果您知道自己在做什么,您可以直接编辑这个文件,但大多数时候并不需要这样做。
- README.rst——一个空的README文件,格式为ReStructuredText,该文件格式用于Python文档。(没有规定说你的文档必须使用.rst格式,对于较简单的情况,可以使用Markdown。)
- tests——带有用于单元测试的脚手架的子目录。如果您还没有为新项目编写测试的习惯,那么您应该养成这样的习惯!
- 最后,是项目名称的子目录,其中包含项目的代码。
3.Poetry中管理Python虚拟环境
对于一个新的Poetry项目,您可能首先需要的是一个Python虚拟环境。与形式一样,诗歌有其独特的处理虚拟环境的方式。Poetry不是将虚拟环境放在项目目录中,而是将它们放在一个根据操作系统不同而不同的集中缓存目录中,如下所示:
- Unix: ~/.cache/pypoetry/virtualenvs
- MacOS: ~/Library/Caches/pypoetry/virtualenvs
- Windows: C:\Users\<username>\AppData\Local\pypoetry\Cache\virtualenvs or %LOCALAPPDATA%\pypoetry\Cache\virtualenvs
Poetry的方法的优势是能够跨项目共享虚拟环境,只要它有意义。但这确实需要改变你的工作习惯。
要在Poetry中设置虚拟环境,转到项目的目录并键入poetry env use python。Poetry将创建一个新的虚拟环境,将其存储在缓存目录中,并为虚拟环境显示一个随机生成的名称(请注意名称,以便以后使用)。
为了方便起见,Poetry还将安装项目在pyproject.toml文件中列出的所有依赖项。如果您想要从其他地方复制一个Poetry项目并在您的系统上设置它,您会发现这个超级有用。
注意,如果您在一个已经有Poetry分配的虚拟环境的项目目录中使用poetry env use python ,那么Poetry将在CLI会话的上下文中激活该虚拟环境。
接下来是比较困难的部分,即让Poetry管理的虚拟环境与IDE一起工作。例如,Visual Studio Code自动检测项目目录中虚拟环境的存在,但依然还检测不到使用Poetry管理的虚拟环境的存在。近期的解决方案是在项目settings.json文件中添加一行,指明Poetry保存虚拟环境的位置:
"python.venvPath": "C:\\Users\\username\\AppData\\Local\\pypoetry\\Cache\\virtualenvs"
在进行此更改后,请确保重新启动Visual Studio Code。
如果你不想让Poetry管理你的虚拟环境,你可以用如下命令禁用它:
poetry config virtualenvs.create false
4.Poetry中添加Python项目依赖
Poetry跟踪了两种类型的项目依赖关系:项目运行所需的包(生产依赖关系),以及仅在开发过程中需要的包(开发依赖关系)。产品依赖关系将包括应用程序功能使用的任何第三方库;开发依赖关系将包括像black、mypy或docutils这样的编码工具。
- 要向项目添加生产依赖关系,请使用poetry add <dependency_name>;
- 要添加开发依赖关系,请使用poetry add <dependency_name> -D。
请注意,在使用命令poetry remove <dependency_name>删除开发依赖项(即使用-D开关添加的依赖项)时,您还可以使用-D开关。
注意,poetry add命令的工作方式与pip安装非常相似,您可以指定包名或Git路径(例如,Git +https://github.com/developer/project.git#branchname)。您还可以配置Poetry使用私人仓库。
解析并安装依赖项后,Poetry在项目目录创建一个名为poetry.lock的文件。这个文件是所有下载依赖项的清单,应该与项目的其余部分一起保存。然后,任何从源代码控制中提取项目副本的人都将得到所有所需包的相同版本。
现在您已经准备好开始项目了。从这一刻开始,您所需要记住的就是使用Poetry——而且只使用Poetry——来管理项目的所有依赖关系和虚拟环境。
5.小结
本文主要介绍了Python项目管理工具,并简要地介绍了如何使用。根据文中所述,赶快去开启体验模式吧。记得来个“三连发”:点赞、转发和关注@牛旦IT课堂。谢谢^_^
相关推荐
-
- 免费英语学习网站(有什么免费学英语的网站)
-
现在网上的高中学习网站很多,像高中教育网校,简单学习网,新东方在线,学而思网校,中小学教育网等。各有利弊,选择适合自己的。并且能不能提高成绩,关键还是靠学生自己努力。我们来看下这些课堂总体特点:封闭课堂在听课过程中屏蔽了聊天、游戏等对学生听...
-
2026-01-18 09:03 off999
-
- 在线铃声下载 免费下载(手机铃声制作app下载)
-
移动那叫“彩铃”,联通那叫“炫铃”,电信那叫“悦铃(可能不对)”总之,这些都是由运营商提供的,有的是免费有的是付费,需要订购。也就是需要你手机发指令或到网上营业厅或直接到柜台办理,然后在设置里设置指定某电话听到的回铃音是什么音乐(这个设置是...
-
2026-01-18 08:51 off999
- 种子搜索神器在线搜索(种子搜索神器在线搜索下载)
-
01.磁力熊磁力熊,是一个内容丰富、功能最为强大的一个磁力搜索网站,通过它不仅仅可以搜索到大量纯净的1080P高分电影,像一些比较小众的影视剧这里也都能找到。02.夕阳小站夕阳小站,虽然网站整体界面设...
-
- 模拟炒股软件app排名(模拟炒股软件app排名榜)
-
同花顺、云掌财经、东方财富网、大智慧同花顺是股民使用比较多的软件了,实时的行情更新,数据分析,模拟炒股都是同花顺的有点所在,在炒股软件使用中占有率非常高。自定义设置的8个板块等按快捷代码查看相当方便(一键查看自选股)。炒股入门首选。大智慧也...
-
2026-01-18 08:03 off999
- oa办公系统功能介绍(oa办公系统都有哪些)
-
以下是一些可能包含在OA办公系统中的常见功能:1.通讯录管理:包括添加、编辑和删除联系人信息,可按部门、职位等分类浏览联系人。2.日程管理:提供个人和团队日程安排功能,可创建、编辑和共享日程,设置...
- 绝地求生(国际服)下载官方(绝地求生国际服下载安装免费正版)
-
首先需要安装和登录Steam(一个游戏平台);然后在Steam搜索"playerunknown'sbattlegrounds"并选择购买;下载并安装游戏,选择要加入的Serv...
- 麻花影视下载(麻花影视下载官方破解版)
-
被人举报了,然后关掉了国内的服务器,现在国内用的都是海外服务器而且用的人太多了所以卡
- 诺基亚n72(诺基亚n72上市时间价格多少)
-
n72是N系列中唯一一款不支持3G的智能机,还有N70。另外说说N72的十大缺点:1、电池待机时间较短,键盘较小,按键不方便2、嘈杂状态下铃声及振动较小,通话声音也较小3、短信书写中没有常用的网络符号...
- 全部破解版游戏大全(破解 版游戏大全)
-
虫虫助手,拇指玩,软件天空,骑士助手,百分网,葫芦侠三楼全民溜溜溜是个软件,是破解版游戏的中心,2.全民溜溜溜对多半的游戏,都有破解版的,修改版的游戏,是不花钱的软件,就像植物大战僵尸这游戏,你能买...
- 经典连连看苹果版(经典连连看3.1原版)
-
3366小游戏是网页模式的,为了玩游戏方便,有很多人想把3366小游戏下载到桌面。如果想把3366小游戏里面的某个游戏单独下载的话,进入3366小游戏首页之后,往右上角看,点击右上角的“设为桌面图标”...
- 益盟经典版下载安装(益盟经典版免费手机版)
-
下载好的,你需要找到下载到那个路径,直接找到路径复制视频粘贴到U盘中即可
- 手机版oa系统怎么使用(oa有手机版吗)
-
泛微oa手机客户端e-mobile,是基于智能移动终端的高效移动协同OA应用,采用先进的页面适配技术,将企业的OA系统完整的延伸到手机终端,企业的原应用系统不需要改造和升级即可快速便捷地进行移动化搭建...
- 动态壁纸app下载(主题动态壁纸app下载)
-
动态壁纸桌面是一款手机动态壁纸桌面主题美化工具。拥有视频壁纸、头像制作,透明主题、3D壁纸、换图标等诸多创意功能于一身的手机壁纸软件;汇集全网优质内容的壁纸大全,壁纸多多。美女,卡通,风景,动漫,搞笑...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
Python 批量卸载关联包 pip-autoremove
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
