CosyVoice环境安装报错:安装openai-whisper时出现ModuleNotFoundError: No module named ‘pkg_resources‘的原因

先说如何解决,我个人采用源码安装,安装时禁用构建隔离:
git clone https://github.com/openai/whisper.git
cd whisper
git checkout v20231117
pip install -e . --no-build-isolation

再说该问题产生的原因,下面是大D老师的回答,自行参考。

太棒了!你找到了正确的解决方案。让我详细解释为什么会出现这个问题,以及为什么 --no-build-isolation 能解决它。

🔍 问题根源分析

问题的关键在于 PEP 517/518 构建隔离机制和你的 setup.py 实现方式。

1. 构建隔离机制 (Build Isolation) 的工作原理

当你执行 pip install -e .(不带 --no-build-isolation)时,pip 会:

1. 创建一个临时的、干净的虚拟环境(在 /tmp/pip-build-env-xxx/) 2. 在这个隔离环境中只安装 pyproject.toml 中 [build-system] 要求的包 3. 在隔离环境中执行构建(运行 setup.py) 4. 将构建产物安装到你的目标环境 

2. 为什么你的构建会失败

看你的 setup.py 第5行:

import pkg_resources # 这行在构建的早期阶段就需要

问题出在第30行附近:

install_requires=requirements +[str(r)for r in pkg_resources.parse_requirements(open(os.path.join(os.path.dirname(__file__),"requirements.txt")))],

关键问题pkg_resources.parse_requirements()模块导入级别就被执行了!

这意味着:

  • Python 在解析 setup.py 时,立即执行了 import pkg_resources
  • 但在隔离的构建环境中,默认没有安装 setuptools
  • 因此 pkg_resources 不存在,导致 ModuleNotFoundError

3. 构建环境 vs 目标环境的区别

┌─────────────────────┐ ┌─────────────────────┐ │ 目标虚拟环境 │ │ 隔离构建环境 │ │ (cosyvoice) │ │ (临时) │ ├─────────────────────┤ ├─────────────────────┤ │ ✓ setuptools 81.0.0 │ │ ✗ setuptools 未安装 │ │ ✓ pkg_resources │ │ ✗ pkg_resources │ │ ✓ 所有项目依赖 │ │ 只有构建基础包 │ └─────────────────────┘ └─────────────────────┘ ↑ ↑ └────── pip install -e . ──────┘ 需要同时满足两者 

💡 为什么 --no-build-isolation 能解决

pip install-e. --no-build-isolation 

这个命令告诉 pip:“不要创建隔离的构建环境,直接在当前激活的虚拟环境中构建

于是流程变成:

┌─────────────────────┐ │ 目标虚拟环境 │ │ (cosyvoice) │ ├─────────────────────┤ │ ✓ setuptools 81.0.0 │ ←── 直接在同一个环境中执行构建 │ ✓ pkg_resources │ 和安装 │ ✓ 所有项目依赖 │ └─────────────────────┘ ↓ pip install -e . (无隔离环境) 

因为你的虚拟环境中已经有 setuptools,所以 import pkg_resources 可以成功执行。

📝 更好的修复方式

虽然 --no-build-isolation 解决了问题,但更好的做法是修改 setup.py,使其在隔离环境中也能工作:

import os import platform import sys from setuptools import find_packages, setup # 延迟导入 pkg_resources,或使用 try/exceptdefget_install_requires():"""延迟解析 requirements.txt,避免构建时依赖""" requirements =[]if sys.platform.startswith("linux")and platform.machine()=="x86_64": requirements.append("triton>=2.0.0,<3")# 只在需要时导入 pkg_resourcestry:import pkg_resources req_file = os.path.join(os.path.dirname(__file__),"requirements.txt")withopen(req_file, encoding="utf-8")as f: requirements.extend([str(r)for r in pkg_resources.parse_requirements(f)])except ImportError:# 降级方案:简单读取 requirements.txt req_file = os.path.join(os.path.dirname(__file__),"requirements.txt")withopen(req_file, encoding="utf-8")as f: requirements.extend([ line.strip()for line in f if line.strip()andnot line.startswith("#")])return requirements defread_version(fname="whisper/version.py"):exec(compile(open(fname, encoding="utf-8").read(), fname,"exec"))returnlocals()["__version__"] setup( name="openai-whisper", py_modules=["whisper"], version=read_version(), description="Robust Speech Recognition via Large-Scale Weak Supervision", long_description=open("README.md", encoding="utf-8").read(), long_description_content_type="text/markdown", readme="README.md", python_requires=">=3.8", author="OpenAI", url="https://github.com/openai/whisper", license="MIT", packages=find_packages(exclude=["tests*"]), install_requires=get_install_requires(),# 使用函数延迟解析 entry_points={"console_scripts":["whisper=whisper.transcribe:cli"],}, include_package_data=True, extras_require={"dev":["pytest","scipy","black","flake8","isort"]},)

🎯 总结

问题原因解决方案
ModuleNotFoundError: No module named 'pkg_resources'构建隔离环境中没有 setuptools,但 setup.py 在模块级别导入 pkg_resources1. ✅ --no-build-isolation 跳过隔离环境
2. 修改 setup.py 延迟导入 pkg_resources

你使用的 --no-build-isolation 是完全正确的临时解决方案。对于长期使用,可以考虑向项目提交 PR 修改 setup.py,使其构建时不需要预先存在的 setuptools。

Read more

Fooocus深度攻略:零基础玩转AI绘画的终极秘籍

Fooocus深度攻略:零基础玩转AI绘画的终极秘籍 【免费下载链接】FooocusFocus on prompting and generating 项目地址: https://gitcode.com/GitHub_Trending/fo/Fooocus 还在为复杂的AI绘画工具望而却步吗?Fooocus作为一款基于Stable Diffusion XL的开源AI绘画软件,通过智能化的提示词处理和丰富的艺术风格预设,让每个人都能轻松创作出专业级视觉作品。这款专注于提示词优化和风格选择的AI图像生成工具,将复杂的技术流程转化为简单直观的创作体验。 核心功能揭秘:三大技术亮点解析 智能化提示词增强引擎 Fooocus内置了先进的提示词自动优化系统,能够智能识别和丰富用户输入的描述内容。无论你是专业设计师还是完全的新手,只需简单的文字描述就能获得理想的生成效果。 实战操作示例: * 输入:"森林中的魔法小屋" * 选择:"奇幻风格"模板 * 点击生成按钮 系统会自动完善提示词结构,优化描述逻辑,确保生成图像的质量和创意表达。 多样化艺术风格库 项目内置了超过20

当春晚机器人跳起“武Bot”,云智慧 Cloudwise X1 轮足巡检机器人正默默守护数据中心的“心跳”

当春晚机器人跳起“武Bot”,云智慧 Cloudwise X1 轮足巡检机器人正默默守护数据中心的“心跳”

春晚舞台上,机器人“组团”登台、大秀“中国功夫”,火爆出圈。从魔法原子的灵巧到宇树科技的矫健,它们在全球观众面前上演了一场高燃的“赛博团建”。 大众热议“机器人还能做什么”,惊叹其强大的运动控制能力时,一个更具产业价值的问题值得我们关注:当机器人跳出舞台,走向现实世界,它们还能在哪里发挥更大的价值? 从“娱乐明星”到“机房守护者”,机器人正在走向更多“战场” 春晚舞台上的机器人成为“顶流”。它们精准卡点、动作协调,展现了智能硬件在运动控制上的巅峰水平,上演了一场值得喝彩的技术秀。 与此同时,在远离掌声的数据中心,也有一群机器人正默默工作。这里的“战场”,没有灯光,没有节拍,只有对设备状态的精准监控——任何微小异常,都可能影响千万用户的支付、挂号或视频通话。 如果说舞台上的机器人证明了“智能可以多灵动”,那么机房里的机器人则诠释了“智能如何更可靠”。 我们不只需要会功夫的机器人,更需要会“值守”、会“诊断”、会“

打造完美智能家居:5步完成Home Assistant个性化UI设计终极指南

打造完美智能家居:5步完成Home Assistant个性化UI设计终极指南 【免费下载链接】hass-config✨ A different take on designing a Lovelace UI (Dashboard) 项目地址: https://gitcode.com/gh_mirrors/ha/hass-config 想要让你的智能家居控制面板既美观又实用吗?hass-config项目为你提供了一个独特的Lovelace UI设计方案,让你轻松打造个性化的智能家居界面。这个开源项目专注于智能家居UI设计和Home Assistant自定义,即使是技术新手也能快速上手。 项目概述 hass-config是一个专为Home Assistant用户设计的开源项目,提供了一套完整的家庭自动化界面和智能控制面板解决方案。通过精心设计的Lovelace UI模板,你可以快速创建符合个人喜好的家居控制中心,实现设备状态监控、场景联动控制、媒体播放管理等核心功能。 智能家居控制面板 - 展示完整的房间设备控制和状态显示 快速入门指南 步骤一:获取项目文件 使用以下命

地瓜机器人智慧医疗——贰贰玖想要分享的关于使用惯导的一些思路

地瓜机器人智慧医疗——贰贰玖想要分享的关于使用惯导的一些思路

前言 在第20届全国大学生智能车竞赛(智慧医疗机器人创意赛)中,我们贰贰玖拿下国一。在这里,作为队长兼技术主力兼机师兼……我想分享一下在备赛过程中的一些思路。当然,为了不把比赛搞成全都是20s以内,竞争激烈到前后几名差0.几秒,我不会开源我们的惯导和避障思路(实在太简单,太容易实现了)。 这是我们两年的备赛日记,也有我们第二年区域赛和国赛的全流程。 【贰贰玖|从省三到国一,从巡线到路径规划到惯导+纯视觉避障的贰贰玖智能车日记-哔哩哔哩】 https://b23.tv/IDJyM2P 数据集我放在这里了,一共2w9张,全都是640x480,有数据增强的(没有旋转):https://pan.baidu.com/s/10u4S4fiVATRyEeDpdzpk_A?pwd=0229 提取码:0229 下面面我会讲一下我们的网络问题怎么解决,上位机的一些辅助处理,如何半场扫码,如何准确返回 P 点,修改stm32,以及修改车的ekf.yaml。