跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
PythonAI算法

CosyVoice 安装 openai-whisper 报错 pkg_resources 缺失原因与解决方案

CosyVoice 安装 openai-whisper 过程中常遇到 ModuleNotFoundError: No module named'pkg_resources'错误。该问题源于 pip 默认启用 PEP 517 构建隔离机制,而隔离环境中未预装 setuptools,导致 setup.py 在模块级别导入 pkg_resources 失败。临时解决方案是使用 --no-build-isolation 参数禁用隔离直接在当前环境构建。长期建议修改 setup.py,将 pkg_resources 导入延迟至函数内部或增加异常处理,确保兼容标准构建流程。

小熊软糖发布于 2026/3/21更新于 2026/5/2419 浏览

解决方案

推荐采用源码安装,并在安装时禁用构建隔离:

git clone https://github.com/openai/whisper.git
cd whisper
git checkout v20231117
pip install -e . --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/except
def get_install_requires():
    """延迟解析 requirements.txt,避免构建时依赖"""
    requirements = []
    if sys.platform.startswith("linux") and platform.machine() == "x86_64":
        requirements.append("triton>=2.0.0,<3")
    # 只在需要时导入 pkg_resources
    try:
        import pkg_resources
        req_file = os.path.join(os.path.dirname(__file__), "requirements.txt")
        with open(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")
        with open(req_file, encoding="utf-8") as f:
            requirements.extend([line.strip() for line in f if line.strip() and not line.startswith("#")])
    return requirements

def read_version(fname="whisper/version.py"):
    exec(compile(open(fname, encoding="utf-8").read(), fname, "exec"))
    return locals()["__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。

目录

  1. 解决方案
  2. 问题根源分析
  3. 1. 构建隔离机制 (Build Isolation) 的工作原理
  4. 2. 为什么你的构建会失败
  5. 3. 构建环境 vs 目标环境的区别
  6. 为什么 --no-build-isolation 能解决
  7. 更好的修复方式
  8. 延迟导入 pkg_resources,或使用 try/except
  9. 总结
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • 人工智能、机器学习与深度学习的关系解析
  • Docker 多平台安装与镜像源配置指南
  • Neo4j 5.26 版本下载安装与配置指南
  • 昇腾平台 DeepSeek-R1 与 Qwen2.5 强化学习训练优化实践
  • Spring Boot 调用 WebService 的两种实现方式:动态与静态调用
  • 昇腾平台下 DeepSeek-R1 与 Qwen2.5 强化学习训练优化实践
  • 数据结构实战:双向链表核心实现与算法解析
  • Windows 部署 OpenAkita 并接入飞书实现本地 AI 助手
  • 大模型微调技术深度解析与实践
  • LAM-YOLO: 无人机小目标检测模型的光照遮挡注意力机制
  • 大型语言模型基础:预训练、生成式模型、提示与对齐技术详解
  • Arduino BLDC 自主巡逻机器人:避障与路径规划实战
  • GTE 中文向量模型技术解析、C-MTEB 表现及 WebUI 部署
  • Llama-Factory 与 LangChain 集成:构建智能 Agent 工作流
  • Linux 高频指令详解:which alias man echo cd cp mv
  • SpringBoot 集成 RabbitMQ 常见消息模式示例
  • cann-recipes-train 实战:昇腾平台 DeepSeek-R1 与 Qwen2.5 强化学习优化
  • Linux 网络层 IP 协议详解
  • ComfyUI 源码部署:基于 Python Embed 版本构建独立整合包
  • AI 风格迁移技术演进:从 AdaIN 到跨模态融合与未来趋势

相关免费在线工具

  • 加密/解密文本

    使用加密算法(如AES、TripleDES、Rabbit或RC4)加密和解密文本明文。 在线工具,加密/解密文本在线工具,online

  • RSA密钥对生成器

    生成新的随机RSA私钥和公钥pem证书。 在线工具,RSA密钥对生成器在线工具,online

  • Mermaid 预览与可视化编辑

    基于 Mermaid.js 实时预览流程图、时序图等图表,支持源码编辑与即时渲染。 在线工具,Mermaid 预览与可视化编辑在线工具,online

  • 随机西班牙地址生成器

    随机生成西班牙地址(支持马德里、加泰罗尼亚、安达卢西亚、瓦伦西亚筛选),支持数量快捷选择、显示全部与下载。 在线工具,随机西班牙地址生成器在线工具,online

  • Gemini 图片去水印

    基于开源反向 Alpha 混合算法去除 Gemini/Nano Banana 图片水印,支持批量处理与下载。 在线工具,Gemini 图片去水印在线工具,online

  • curl 转代码

    解析常见 curl 参数并生成 fetch、axios、PHP curl 或 Python requests 示例代码。 在线工具,curl 转代码在线工具,online