0

0

Python hatch 的环境管理与脚本定义

冷炫風刃

冷炫風刃

发布时间:2026-02-15 17:20:02

|

326人浏览过

|

来源于php中文网

原创

hatch env create 失败因未识别 python:需用 pyenv/asdf 正确安装并注册,windows 需确保注册表项;脚本需在 hatch.toml 的 [scripts] 下定义;hatch run 自动管理环境并安装项目,hatch env run 仅执行已有环境;prune 不清理自定义路径环境。

python hatch 的环境管理与脚本定义

hatch env create 创建失败:找不到 Python 版本

hatch 默认不会自动安装 Python,它只调用系统已有的 python 或按 pyenvasdf 等工具注册的版本。如果你执行 hatch env create py39 报错 No Python interpreter found for specifier 'py39',大概率是 hatch 根本没看到你装的 Python。

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 先运行 hatch env python list,看 hatch 能识别出哪些 Python —— 它不依赖 $PATH,而是查 pyenvversions 目录、asdf 的 shim 路径,或系统 /usr/bin 下的硬链接
  • 如果用 pyenv,确保已执行 pyenv install 3.9.18pyenv global 3.9.18(或至少 pyenv local),再试 hatch env create
  • Windows 用户注意:hatch 不识别 py -3.9 这类启动器,必须让 pyenv 或官方安装器把 Python 注册进系统“PythonInstallPath”注册表项,否则 hatch 查不到

hatch.toml 中 [scripts] 定义后不生效

脚本定义在 hatch.toml 里,但运行 hatch run lint 提示 Unknown script 'lint',常见原因是配置位置或格式不对。

实操建议:

立即学习Python免费学习笔记(深入)”;

  • [scripts] 必须放在项目根目录的 hatch.toml 中,不能放在 pyproject.toml 里(除非你明确用 [tool.hatch.scripts]
  • 不要写成 [tool.hatch.scripts] 后又在同个文件里写 [scripts] —— hatch 只认其中一种,优先级混乱时直接忽略
  • 脚本值支持字符串(如 lint = "ruff check .")或数组(如 test = ["pytest", "-x", "tests/"]),但不能混用;数组中每个元素必须是纯字符串,不能带 && 或管道符
  • 如果脚本依赖未安装的包(比如 ruff),hatch 不会自动装,需提前在对应环境中 pip install ruff,或改用 hatch run --no-project lint 让 hatch 在干净环境里装依赖再跑

hatch env run 与 hatch run 的行为差异

这两个命令看起来都“跑东西”,但触发的环境和隔离程度完全不同:一个针对已有环境,一个针对项目本身。

Kuwebs企业网站管理系统3.1.5 UTF8
Kuwebs企业网站管理系统3.1.5 UTF8

酷纬企业网站管理系统Kuwebs是酷纬信息开发的为企业网站提供解决方案而开发的营销型网站系统。在线留言模块、常见问题模块、友情链接模块。前台采用DIV+CSS,遵循SEO标准。 1.支持中文、英文两种版本,后台可以在不同的环境下编辑中英文。 3.程序和界面分离,提供通用的PHP标准语法字段供前台调用,可以为不同的页面设置不同的风格。 5.支持google地图生成、自定义标题、自定义关键词、自定义描

下载

实操建议:

立即学习Python免费学习笔记(深入)”;

  • hatch env run myenv -- pytest:在名为 myenv 的已存在环境中执行 pytest,不检查 pyproject.toml 里的依赖,也不激活项目包(即你的本地代码不会被 import)
  • hatch run pytest:先检查 [project.optional-dependencies][tool.hatch.envs.test.dependencies],创建/复用一个临时环境,安装项目(editable 模式)、测试依赖,再跑 pytest —— 这才是开发时该用的方式
  • 容易踩坑的是:误用 hatch env run 调试脚本,结果发现 import mypackage 报错 —— 因为那个环境压根没装你的项目

hatch env prune 清不掉旧环境

hatch env prune 默认只清理“由 hatch 自动管理”的环境,手动用 hatch env create --python 3.8 myold 创建的环境会被清理,但通过 hatch env create myold(没指定 Python)创建的、或名字含点号/下划线的,可能被跳过。

实操建议:

立即学习Python免费学习笔记(深入)”;

  • 运行 hatch env list,确认待删环境名是否出现在列表中 —— 如果没列出来,prune 就不会碰它
  • hatch 判断“可清理”的依据是环境路径是否符合其内部命名规则(如 .venv/py39),自定义路径(如 --path /tmp/myenv)永远不被 prune 触及
  • 最稳妥的清理方式是直接删目录:rm -rf $(hatch env show --path myold),再补一句 hatch env remove myold 同步 hatch 内部记录

环境路径生成逻辑藏得深,不同 hatch 版本对“合法环境名”的判断略有出入,别依赖 prune 做自动化清理,手动删更可控。

热门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安装使用方法的更多内容。

348

2023.10.09

更新pip版本
更新pip版本

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

425

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、保存并关闭文件即可。

785

2024.12.23

python升级pip
python升级pip

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

356

2025.07.23

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

551

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1552

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

640

2023.11.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

139

2026.02.13

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

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

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